Chilkat Online Tools

unicodeCpp / MongoDB Atlas / Create One Cluster

Back to Collection Items

#include <CkHttpW.h>
#include <CkJsonObjectW.h>
#include <CkHttpResponseW.h>

void ChilkatSample(void)
    {
    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkHttpW http;
    bool success;

    http.put_DigestAuth(true);
    http.put_Login(L"username");
    http.put_Password(L"password");

    // Use this online tool to generate code from sample JSON: Generate Code to Create JSON

    // The following JSON is sent in the request body.

    // {
    //   "name": "SingleRegionCluster",
    //   "diskSizeGB": 100,
    //   "numShards": 1,
    //   "providerSettings": {
    //     "providerName": "AWS",
    //     "instanceSizeName": "M10",
    //     "regionName": "US_EAST_1"
    //   },
    //   "clusterType": "REPLICASET",
    //   "replicationFactor": 3,
    //   "replicationSpecs": [
    //     {
    //       "numShards": 1,
    //       "regionsConfig": {
    //         "US_EAST_1": {
    //           "analyticsNodes": 0,
    //           "electableNodes": 3,
    //           "priority": 7,
    //           "readOnlyNodes": 0
    //         }
    //       },
    //       "zoneName": "Zone 1"
    //     }
    //   ],
    //   "backupEnabled": false,
    //   "providerBackupEnabled": true,
    //   "autoScaling": {
    //     "diskGBEnabled": true
    //   }
    // }

    CkJsonObjectW json;
    json.UpdateString(L"name",L"SingleRegionCluster");
    json.UpdateInt(L"diskSizeGB",100);
    json.UpdateInt(L"numShards",1);
    json.UpdateString(L"providerSettings.providerName",L"AWS");
    json.UpdateString(L"providerSettings.instanceSizeName",L"M10");
    json.UpdateString(L"providerSettings.regionName",L"US_EAST_1");
    json.UpdateString(L"clusterType",L"REPLICASET");
    json.UpdateInt(L"replicationFactor",3);
    json.UpdateInt(L"replicationSpecs[0].numShards",1);
    json.UpdateInt(L"replicationSpecs[0].regionsConfig.US_EAST_1.analyticsNodes",0);
    json.UpdateInt(L"replicationSpecs[0].regionsConfig.US_EAST_1.electableNodes",3);
    json.UpdateInt(L"replicationSpecs[0].regionsConfig.US_EAST_1.priority",7);
    json.UpdateInt(L"replicationSpecs[0].regionsConfig.US_EAST_1.readOnlyNodes",0);
    json.UpdateString(L"replicationSpecs[0].zoneName",L"Zone 1");
    json.UpdateBool(L"backupEnabled",false);
    json.UpdateBool(L"providerBackupEnabled",true);
    json.UpdateBool(L"autoScaling.diskGBEnabled",true);

    http.SetRequestHeader(L"Content-Type",L"application/json");

    CkHttpResponseW *resp = http.PostJson3(L"https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/clusters",L"application/json",json);
    if (http.get_LastMethodSuccess() == false) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    wprintf(L"%d\n",resp->get_StatusCode());
    wprintf(L"%s\n",resp->bodyStr());
    delete resp;
    }

Curl Command

curl -X POST
	--digest -u 'username:password'
	-H "Content-Type: application/json"
	-d '{
         "name": "SingleRegionCluster",
         "diskSizeGB": 100,
         "numShards": 1,
         "providerSettings": {
           "providerName": "AWS",
           "instanceSizeName": "M10",
           "regionName": "US_EAST_1"
         },
         "clusterType" : "REPLICASET",
         "replicationFactor": 3,
         "replicationSpecs": [{
           "numShards": 1,
           "regionsConfig": {
             "US_EAST_1": {
               "analyticsNodes": 0,
               "electableNodes": 3,
               "priority": 7,
               "readOnlyNodes": 0
             }
           },
           "zoneName": "Zone 1"
         }],
         "backupEnabled": false,
         "providerBackupEnabled" : true,
         "autoScaling": {
           "diskGBEnabled": true
         }
       }'
https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/clusters

Postman Collection Item JSON

{
  "name": "Create One Cluster",
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "type": "text",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "       {\n         \"name\": \"SingleRegionCluster\",\n         \"diskSizeGB\": 100,\n         \"numShards\": 1,\n         \"providerSettings\": {\n           \"providerName\": \"AWS\",\n           \"instanceSizeName\": \"M10\",\n           \"regionName\": \"US_EAST_1\"\n         },\n         \"clusterType\" : \"REPLICASET\",\n         \"replicationFactor\": 3,\n         \"replicationSpecs\": [{\n           \"numShards\": 1,\n           \"regionsConfig\": {\n             \"US_EAST_1\": {\n               \"analyticsNodes\": 0,\n               \"electableNodes\": 3,\n               \"priority\": 7,\n               \"readOnlyNodes\": 0\n             }\n           },\n           \"zoneName\": \"Zone 1\"\n         }],\n         \"backupEnabled\": false,\n         \"providerBackupEnabled\" : true,\n         \"autoScaling\": {\n           \"diskGBEnabled\": true\n         }\n       }"
    },
    "url": {
      "raw": "{{base_url}}/api/atlas/{{version}}/groups/{{ProjectID}}/clusters",
      "host": [
        "{{base_url}}"
      ],
      "path": [
        "api",
        "atlas",
        "{{version}}",
        "groups",
        "{{ProjectID}}",
        "clusters"
      ]
    },
    "description": "Create a cluster in the specified project.\n\nhttps://docs.atlas.mongodb.com/reference/api/clusters-create-one/"
  },
  "response": [
  ]
}