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