Unicode C
Unicode C
EC2 Check Instance Status
See more Amazon EC2 Examples
Demonstrates how to send a request to check the status of Amazon EC2 instances.Chilkat Unicode C Downloads
#include <C_CkRestW.h>
#include <C_CkAuthAwsW.h>
#include <C_CkXmlW.h>
void ChilkatSample(void)
{
BOOL success;
HCkRestW rest;
BOOL bTls;
int port;
BOOL bAutoReconnect;
HCkAuthAwsW authAws;
const wchar_t *responseXml;
HCkXmlW xml;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
rest = CkRestW_Create();
// Connect to the Amazon AWS server.
// such as https://ec2.amazonaws.com/
bTls = TRUE;
port = 443;
bAutoReconnect = TRUE;
success = CkRestW_Connect(rest,L"ec2.us-west-2.amazonaws.com",port,bTls,bAutoReconnect);
// Provide AWS credentials for the REST call.
authAws = CkAuthAwsW_Create();
CkAuthAwsW_putAccessKey(authAws,L"AWS_ACCESS_KEY");
CkAuthAwsW_putSecretKey(authAws,L"AWS_SECRET_KEY");
// the region should match the region part of the domain passed to the REST connect method (above).
CkAuthAwsW_putRegion(authAws,L"us-west-2");
CkAuthAwsW_putServiceName(authAws,L"ec2");
CkRestW_SetAuthAws(rest,authAws);
CkRestW_AddQueryParam(rest,L"Action",L"DescribeInstanceStatus");
CkRestW_AddQueryParam(rest,L"Version",L"2016-11-15");
CkRestW_AddQueryParam(rest,L"InstanceId.1",L"i-999719995399c9999");
// If you have additional instances to check, then add them with .2, .3, etc.
CkRestW_AddQueryParam(rest,L"InstanceId.2",L"i-999719995399c0000");
CkRestW_AddQueryParam(rest,L"InstanceId.3",L"i-999719995399c0111");
// ...
// Instead of checking specific instances, you can check all instances by
// sending the IncludeAllInstances param
CkRestW_AddQueryParam(rest,L"IncludeAllInstances",L"true");
responseXml = CkRestW_fullRequestNoBody(rest,L"GET",L"/");
if (CkRestW_getLastMethodSuccess(rest) != TRUE) {
wprintf(L"%s\n",CkRestW_lastErrorText(rest));
CkRestW_Dispose(rest);
CkAuthAwsW_Dispose(authAws);
return;
}
// A successful response will have a status code equal to 200.
if (CkRestW_getResponseStatusCode(rest) != 200) {
wprintf(L"response status code = %d\n",CkRestW_getResponseStatusCode(rest));
wprintf(L"response status text = %s\n",CkRestW_responseStatusText(rest));
wprintf(L"response header: %s\n",CkRestW_responseHeader(rest));
wprintf(L"response body: %s\n",responseXml);
CkRestW_Dispose(rest);
CkAuthAwsW_Dispose(authAws);
return;
}
// Examine the successful XML response.
xml = CkXmlW_Create();
CkXmlW_LoadXml(xml,responseXml);
wprintf(L"%s\n",CkXmlW_getXml(xml));
// Here is a sample response:
// Use this online tool to generate parsing code from sample XML:
// Generate Parsing Code from XML
// <DescribeInstanceStatusResponse xmlns="http://ec2.amazonaws.com/doc/2016-11-15/">
// <requestId>3be1508e-c444-4fef-89cc-0b1223c4f02fEXAMPLE</requestId>
// <instanceStatusSet>
// <item>
// <instanceId>i-1234567890abcdef0</instanceId>
// <availabilityZone>us-east-1d</availabilityZone>
// <instanceState>
// <code>16</code>
// <name>running</name>
// </instanceState>
// <systemStatus>
// <status>impaired</status>
// <details>
// <item>
// <name>reachability</name>
// <status>failed</status>
// <impairedSince>YYYY-MM-DDTHH:MM:SS.000Z</impairedSince>
// </item>
// </details>
// </systemStatus>
// <instanceStatus>
// <status>impaired</status>
// <details>
// <item>
// <name>reachability</name>
// <status>failed</status>
// <impairedSince>YYYY-MM-DDTHH:MM:SS.000Z</impairedSince>
// </item>
// </details>
// </instanceStatus>
// <eventsSet>
// <item>
// <code>instance-retirement</code>
// <description>The instance is running on degraded hardware</description>
// <notBefore>YYYY-MM-DDTHH:MM:SS+0000</notBefore>
// <notAfter>YYYY-MM-DDTHH:MM:SS+0000</notAfter>
// </item>
// </eventsSet>
// </item>
// <item>
// <instanceId>i-0598c7d356eba48d7</instanceId>
// <availabilityZone>us-east-1d</availabilityZone>
// <instanceState>
// <code>16</code>
// <name>running</name>
// </instanceState>
// <systemStatus>
// <status>ok</status>
// <details>
// <item>
// <name>reachability</name>
// <status>passed</status>
// </item>
// </details>
// </systemStatus>
// <instanceStatus>
// <status>ok</status>
// <details>
// <item>
// <name>reachability</name>
// <status>passed</status>
// </item>
// </details>
// </instanceStatus>
// <eventsSet>
// <item>
// <code>instance-reboot</code>
// <description>The instance is scheduled for a reboot</description>
// <notBefore>YYYY-MM-DDTHH:MM:SS+0000</notBefore>
// <notAfter>YYYY-MM-DDTHH:MM:SS+0000</notAfter>
// </item>
// </eventsSet>
// </item>
// <item>
// <instanceId>i-0987654321abcdef0</instanceId>
// <availabilityZone>us-east-1d</availabilityZone>
// <instanceState>
// <code>16</code>
// <name>running</name>
// </instanceState>
// <systemStatus>
// <status>ok</status>
// <details>
// <item>
// <name>reachability</name>
// <status>passed</status>
// </item>
// </details>
// </systemStatus>
// <instanceStatus>
// <status>ok</status>
// <details>
// <item>
// <name>reachability</name>
// <status>passed</status>
// </item>
// </details>
// </instanceStatus>
// </item>
// <item>
// <instanceId>i-0598c7d356eba48d8</instanceId>
// <availabilityZone>us-east-1d</availabilityZone>
// <instanceState>
// <code>16</code>
// <name>running</name>
// </instanceState>
// <systemStatus>
// <status>ok</status>
// <details>
// <item>
// <name>reachability</name>
// <status>passed</status>
// </item>
// </details>
// </systemStatus>
// <instanceStatus>
// <status>insufficient-data</status>
// <details>
// <item>
// <name>reachability</name>
// <status>insufficient-data</status>
// </item>
// </details>
// </instanceStatus>
// </item>
// </instanceStatusSet>
// </DescribeInstanceStatusResponse>
CkRestW_Dispose(rest);
CkAuthAwsW_Dispose(authAws);
CkXmlW_Dispose(xml);
}