Chilkat Online Tools

Perl / MongoDB Atlas / Start the Migration Cutover

Back to Collection Items

use chilkat();

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

$http = chilkat::CkHttp->new();

$http->put_DigestAuth(1);
$http->put_Login("username");
$http->put_Password("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.

# {
#   "source": {
#     "clusterName": "exampleClusterA",
#     "groupId": "9b43a5b329223c3a1591a678",
#     "username": "example",
#     "password": "string",
#     "ssl": true,
#     "caCertificatePath": "/path/to/ca",
#     "managedAuthentication": false
#   },
#   "destination": {
#     "groupId": "e01c9427f054fe80745f3f6c",
#     "clusterName": "exampleClusterB"
#   },
#   "migrationHosts": [
#     "vm001.example.com"
#   ],
#   "dropEnabled": true
# }

$json = chilkat::CkJsonObject->new();
$json->UpdateString("source.clusterName","exampleClusterA");
$json->UpdateString("source.groupId","9b43a5b329223c3a1591a678");
$json->UpdateString("source.username","example");
$json->UpdateString("source.password","string");
$json->UpdateBool("source.ssl",1);
$json->UpdateString("source.caCertificatePath","/path/to/ca");
$json->UpdateBool("source.managedAuthentication",0);
$json->UpdateString("destination.groupId","e01c9427f054fe80745f3f6c");
$json->UpdateString("destination.clusterName","exampleClusterB");
$json->UpdateString("migrationHosts[0]","vm001.example.com");
$json->UpdateBool("dropEnabled",1);

$sbRequestBody = chilkat::CkStringBuilder->new();
$json->EmitSb($sbRequestBody);

# resp is a HttpResponse
$resp = $http->PTextSb("PUT","https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/liveMigrations/{{LIVE-MIGRATION-ID}}/cutover",$sbRequestBody,"utf-8","application/json",0,0);
if ($http->get_LastMethodSuccess() == 0) {
    print $http->lastErrorText() . "\r\n";
    exit;
}

print $resp->get_StatusCode() . "\r\n";
print $resp->bodyStr() . "\r\n";

Curl Command

curl -X PUT
	--digest -u 'username:password'
	-d '{
    "source": {
        "clusterName": "exampleClusterA",
        "groupId": "9b43a5b329223c3a1591a678",
        "username": "example",
        "password": "string",
        "ssl": true,
        "caCertificatePath": "/path/to/ca",
        "managedAuthentication": false
    },
    "destination": {
        "groupId": "e01c9427f054fe80745f3f6c",
        "clusterName": "exampleClusterB"
    },
    "migrationHosts": [
        "vm001.example.com"
    ],
    "dropEnabled": true
}'
https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/liveMigrations/{{LIVE-MIGRATION-ID}}/cutover

Postman Collection Item JSON

{
  "name": "Start the Migration Cutover",
  "request": {
    "method": "PUT",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"source\": {\n        \"clusterName\": \"exampleClusterA\",\n        \"groupId\": \"9b43a5b329223c3a1591a678\",\n        \"username\": \"example\",\n        \"password\": \"string\",\n        \"ssl\": true,\n        \"caCertificatePath\": \"/path/to/ca\",\n        \"managedAuthentication\": false\n    },\n    \"destination\": {\n        \"groupId\": \"e01c9427f054fe80745f3f6c\",\n        \"clusterName\": \"exampleClusterB\"\n    },\n    \"migrationHosts\": [\n        \"vm001.example.com\"\n    ],\n    \"dropEnabled\": true\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{base_url}}/api/atlas/{{version}}/groups/{{ProjectID}}/liveMigrations/{{LIVE-MIGRATION-ID}}/cutover",
      "host": [
        "{{base_url}}"
      ],
      "path": [
        "api",
        "atlas",
        "{{version}}",
        "groups",
        "{{ProjectID}}",
        "liveMigrations",
        "{{LIVE-MIGRATION-ID}}",
        "cutover"
      ]
    },
    "description": "https://docs.atlas.mongodb.com/reference/api/live-migration/return-one-specific-migration/"
  },
  "response": [
  ]
}