Chilkat Online Tools

C / MongoDB Atlas / Create One Cluster

Back to Collection Items

#include <C_CkHttp.h>
#include <C_CkJsonObject.h>
#include <C_CkHttpResponse.h>

void ChilkatSample(void)
    {
    HCkHttp http;
    BOOL success;
    HCkJsonObject json;
    HCkHttpResponse resp;

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

    http = CkHttp_Create();

    CkHttp_putDigestAuth(http,TRUE);
    CkHttp_putLogin(http,"username");
    CkHttp_putPassword(http,"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 = CkJsonObject_Create();
    CkJsonObject_UpdateString(json,"name","SingleRegionCluster");
    CkJsonObject_UpdateInt(json,"diskSizeGB",100);
    CkJsonObject_UpdateInt(json,"numShards",1);
    CkJsonObject_UpdateString(json,"providerSettings.providerName","AWS");
    CkJsonObject_UpdateString(json,"providerSettings.instanceSizeName","M10");
    CkJsonObject_UpdateString(json,"providerSettings.regionName","US_EAST_1");
    CkJsonObject_UpdateString(json,"clusterType","REPLICASET");
    CkJsonObject_UpdateInt(json,"replicationFactor",3);
    CkJsonObject_UpdateInt(json,"replicationSpecs[0].numShards",1);
    CkJsonObject_UpdateInt(json,"replicationSpecs[0].regionsConfig.US_EAST_1.analyticsNodes",0);
    CkJsonObject_UpdateInt(json,"replicationSpecs[0].regionsConfig.US_EAST_1.electableNodes",3);
    CkJsonObject_UpdateInt(json,"replicationSpecs[0].regionsConfig.US_EAST_1.priority",7);
    CkJsonObject_UpdateInt(json,"replicationSpecs[0].regionsConfig.US_EAST_1.readOnlyNodes",0);
    CkJsonObject_UpdateString(json,"replicationSpecs[0].zoneName","Zone 1");
    CkJsonObject_UpdateBool(json,"backupEnabled",FALSE);
    CkJsonObject_UpdateBool(json,"providerBackupEnabled",TRUE);
    CkJsonObject_UpdateBool(json,"autoScaling.diskGBEnabled",TRUE);

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

    resp = CkHttp_PostJson3(http,"https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/clusters","application/json",json);
    if (CkHttp_getLastMethodSuccess(http) == FALSE) {
        printf("%s\n",CkHttp_lastErrorText(http));
        CkHttp_Dispose(http);
        CkJsonObject_Dispose(json);
        return;
    }

    printf("%d\n",CkHttpResponse_getStatusCode(resp));
    printf("%s\n",CkHttpResponse_bodyStr(resp));
    CkHttpResponse_Dispose(resp);


    CkHttp_Dispose(http);
    CkJsonObject_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": [
  ]
}