Sample code for 30+ languages & platforms
Unicode C++

Create S3 Bucket in a Region

See more Amazon S3 Examples

Demonstrates how to create an S3 bucket in a specified region. This example will create a bucket in the eu-west-2 region.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkRestW.h>
#include <CkAuthAwsW.h>
#include <CkStringBuilderW.h>
#include <CkXmlW.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkRestW rest;

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

    // Provide AWS credentials for the REST call.
    CkAuthAwsW authAws;
    authAws.put_AccessKey(L"AWS_ACCESS_KEY");
    authAws.put_SecretKey(L"AWS_SECRET_KEY");
    authAws.put_ServiceName(L"s3");
    success = rest.SetAuthAws(authAws);

    // We'll send a PUT request having an XML body such as this:
    // <CreateBucketConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/"> 
    //   <LocationConstraint>BucketRegion</LocationConstraint> 
    //   </CreateBucketConfiguration>

    // Create the XML body specifying the region as "eu-west-2"
    const wchar_t *bucketRegion = L"eu-west-2";
    CkStringBuilderW sbBucketRegion;
    sbBucketRegion.Append(bucketRegion);

    // We only need to specify the LocationConstraint if the bucket's region is NOT us-east-1
    CkXmlW xml;
    if (!sbBucketRegion.ContentsEqual(L"us-east-1")) {
        xml.put_Tag(L"CreateBucketConfiguration");
        xml.AddAttribute(L"xmlns",L"http://s3.amazonaws.com/doc/2006-03-01/");
        xml.UpdateChildContent(L"LocationConstraint",L"eu-west-2");
    }

    // --------------------------------------------------------------
    // IMPORTANT: To create a bucket in the default us-east-1 region,
    // do not add the LocationConstraint.  Adding a LocationConstraint of "us-east-1"
    // causes an error "The specified location-constraint is not valid."
    // By default, the bucket is created in us-east-1 by sending a PUT with an empty body.
    // --------------------------------------------------------------

    // Set the bucket name via the HOST header.
    // In this case, the bucket name is "chilkateuwest2".
    rest.put_Host(L"chilkateuwest2.s3.amazonaws.com");

    // Make the call to create the bucket.
    const wchar_t *responseStr = 0;
    if (!sbBucketRegion.ContentsEqual(L"us-east-1")) {
        responseStr = rest.fullRequestString(L"PUT",L"/",xml.getXml());
    }
    else {
        // If the bucket is to be created in the us-east-1 region (the default region)
        // just send a PUT with no body.
        responseStr = rest.fullRequestNoBody(L"PUT",L"/");
    }

    if (rest.get_LastMethodSuccess() != true) {
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    if (rest.get_ResponseStatusCode() != 200) {
        wprintf(L"status code = %d\n",rest.get_ResponseStatusCode());
        CkXmlW responseXml;
        responseXml.LoadXml(responseStr);
        wprintf(L"%s\n",responseXml.getXml());
        wprintf(L"Failed.\n");
        return;
    }

    wprintf(L"Bucket in the eu-west-2 region created.\n");
    }