Chilkat Online Tools

Python / MongoDB Atlas / Start the Migration Cutover

Back to Collection Items

import sys
import chilkat2

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

http = chilkat2.Http()

http.DigestAuth = True
http.Login = "username"
http.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 = chilkat2.JsonObject()
json.UpdateString("source.clusterName","exampleClusterA")
json.UpdateString("source.groupId","9b43a5b329223c3a1591a678")
json.UpdateString("source.username","example")
json.UpdateString("source.password","string")
json.UpdateBool("source.ssl",True)
json.UpdateString("source.caCertificatePath","/path/to/ca")
json.UpdateBool("source.managedAuthentication",False)
json.UpdateString("destination.groupId","e01c9427f054fe80745f3f6c")
json.UpdateString("destination.clusterName","exampleClusterB")
json.UpdateString("migrationHosts[0]","vm001.example.com")
json.UpdateBool("dropEnabled",True)

sbRequestBody = chilkat2.StringBuilder()
json.EmitSb(sbRequestBody)

# resp is a CkHttpResponse
resp = http.PTextSb("PUT","https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/liveMigrations/{{LIVE-MIGRATION-ID}}/cutover",sbRequestBody,"utf-8","application/json",False,False)
if (http.LastMethodSuccess == False):
    print(http.LastErrorText)
    sys.exit()

print(str(resp.StatusCode))
print(resp.BodyStr)

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