Chilkat Online Tools

unicodeC / MongoDB Atlas / Create One Cluster

Back to Collection Items

#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>

void ChilkatSample(void)
    {
    HCkHttpW http;
    BOOL success;
    HCkJsonObjectW json;
    HCkHttpResponseW resp;

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

    http = CkHttpW_Create();

    CkHttpW_putDigestAuth(http,TRUE);
    CkHttpW_putLogin(http,L"username");
    CkHttpW_putPassword(http,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
    //   }
    // }

    json = CkJsonObjectW_Create();
    CkJsonObjectW_UpdateString(json,L"name",L"SingleRegionCluster");
    CkJsonObjectW_UpdateInt(json,L"diskSizeGB",100);
    CkJsonObjectW_UpdateInt(json,L"numShards",1);
    CkJsonObjectW_UpdateString(json,L"providerSettings.providerName",L"AWS");
    CkJsonObjectW_UpdateString(json,L"providerSettings.instanceSizeName",L"M10");
    CkJsonObjectW_UpdateString(json,L"providerSettings.regionName",L"US_EAST_1");
    CkJsonObjectW_UpdateString(json,L"clusterType",L"REPLICASET");
    CkJsonObjectW_UpdateInt(json,L"replicationFactor",3);
    CkJsonObjectW_UpdateInt(json,L"replicationSpecs[0].numShards",1);
    CkJsonObjectW_UpdateInt(json,L"replicationSpecs[0].regionsConfig.US_EAST_1.analyticsNodes",0);
    CkJsonObjectW_UpdateInt(json,L"replicationSpecs[0].regionsConfig.US_EAST_1.electableNodes",3);
    CkJsonObjectW_UpdateInt(json,L"replicationSpecs[0].regionsConfig.US_EAST_1.priority",7);
    CkJsonObjectW_UpdateInt(json,L"replicationSpecs[0].regionsConfig.US_EAST_1.readOnlyNodes",0);
    CkJsonObjectW_UpdateString(json,L"replicationSpecs[0].zoneName",L"Zone 1");
    CkJsonObjectW_UpdateBool(json,L"backupEnabled",FALSE);
    CkJsonObjectW_UpdateBool(json,L"providerBackupEnabled",TRUE);
    CkJsonObjectW_UpdateBool(json,L"autoScaling.diskGBEnabled",TRUE);

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

    resp = CkHttpW_PostJson3(http,L"https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/clusters",L"application/json",json);
    if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(json);
        return;
    }

    wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
    wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
    CkHttpResponseW_Dispose(resp);


    CkHttpW_Dispose(http);
    CkJsonObjectW_Dispose(json);

    }

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": [
  ]
}