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