Sample code for 30+ languages & platforms
Unicode C

S3 List Buckets using an STS Session Token

See more AWS Security Token Service Examples

This is an example showing how to use an STS session token in an Amazon AWS request. This example will list S3 buckets using a previously obtained session token.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkXmlW.h>
#include <C_CkRestW.h>
#include <C_CkAuthAwsW.h>
#include <C_CkStringBuilderW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkXmlW xmlToken;
    HCkRestW rest;
    BOOL bTls;
    int port;
    BOOL bAutoReconnect;
    HCkAuthAwsW authAws;
    HCkStringBuilderW sbResponse;
    int statusCode;
    HCkXmlW xml;

    success = FALSE;

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    // See Get AWS STS Session Token for sample code to get the session token XML.
    xmlToken = CkXmlW_Create();
    success = CkXmlW_LoadXmlFile(xmlToken,L"qa_data/tokens/aws_session_token.xml");
    if (success == FALSE) {
        wprintf(L"%s\n",CkXmlW_lastErrorText(xmlToken));
        CkXmlW_Dispose(xmlToken);
        return;
    }

    rest = CkRestW_Create();

    // Connect to the Amazon AWS REST server.
    bTls = TRUE;
    port = 443;
    bAutoReconnect = TRUE;
    success = CkRestW_Connect(rest,L"s3.amazonaws.com",port,bTls,bAutoReconnect);

    // Provide AWS credentials for the REST call.
    authAws = CkAuthAwsW_Create();

    // The purpose of this example is to show how to use the temporary AccessKeyId, SecretAccessKey, and SessionToken.
    CkAuthAwsW_putAccessKey(authAws,CkXmlW_getChildContent(xmlToken,L"GetSessionTokenResult|Credentials|AccessKeyId"));
    CkAuthAwsW_putSecretKey(authAws,CkXmlW_getChildContent(xmlToken,L"GetSessionTokenResult|Credentials|SecretAccessKey"));
    CkAuthAwsW_putServiceName(authAws,L"s3");
    success = CkRestW_SetAuthAws(rest,authAws);

    CkRestW_AddQueryParam(rest,L"X-Amz-Security-Token",CkXmlW_getChildContent(xmlToken,L"GetSessionTokenResult|Credentials|SessionToken"));

    sbResponse = CkStringBuilderW_Create();
    success = CkRestW_FullRequestNoBodySb(rest,L"GET",L"/",sbResponse);
    if (success != TRUE) {
        wprintf(L"%s\n",CkRestW_lastErrorText(rest));
        CkXmlW_Dispose(xmlToken);
        CkRestW_Dispose(rest);
        CkAuthAwsW_Dispose(authAws);
        CkStringBuilderW_Dispose(sbResponse);
        return;
    }

    statusCode = CkRestW_getResponseStatusCode(rest);
    wprintf(L"Response status code = %d\n",statusCode);

    xml = CkXmlW_Create();
    CkXmlW_LoadSb(xml,sbResponse,TRUE);
    wprintf(L"%s\n",CkXmlW_getXml(xml));

    if (statusCode != 200) {
        wprintf(L"Failed.  See error information in the XML.\n");
        CkXmlW_Dispose(xmlToken);
        CkRestW_Dispose(rest);
        CkAuthAwsW_Dispose(authAws);
        CkStringBuilderW_Dispose(sbResponse);
        CkXmlW_Dispose(xml);
        return;
    }



    CkXmlW_Dispose(xmlToken);
    CkRestW_Dispose(rest);
    CkAuthAwsW_Dispose(authAws);
    CkStringBuilderW_Dispose(sbResponse);
    CkXmlW_Dispose(xml);

    }