Chilkat Online Tools

VBScript / MongoDB Atlas / Start the Migration Cutover

Back to Collection Items

Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

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

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Http")
set http = CreateObject("Chilkat.Http")

http.DigestAuth = 1
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
' }

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject")
set json = CreateObject("Chilkat.JsonObject")
success = json.UpdateString("source.clusterName","exampleClusterA")
success = json.UpdateString("source.groupId","9b43a5b329223c3a1591a678")
success = json.UpdateString("source.username","example")
success = json.UpdateString("source.password","string")
success = json.UpdateBool("source.ssl",1)
success = json.UpdateString("source.caCertificatePath","/path/to/ca")
success = json.UpdateBool("source.managedAuthentication",0)
success = json.UpdateString("destination.groupId","e01c9427f054fe80745f3f6c")
success = json.UpdateString("destination.clusterName","exampleClusterB")
success = json.UpdateString("migrationHosts[0]","vm001.example.com")
success = json.UpdateBool("dropEnabled",1)

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder")
set sbRequestBody = CreateObject("Chilkat.StringBuilder")
success = json.EmitSb(sbRequestBody)

' resp is a Chilkat.HttpResponse
Set 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.LastMethodSuccess = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

outFile.WriteLine(resp.StatusCode)
outFile.WriteLine(resp.BodyStr)


outFile.Close

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