Chilkat Online Tools

TCL / MongoDB Atlas / Update One Data Lake

Back to Collection Items

load ./chilkat.dll

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

set http [new_CkHttp]

CkHttp_put_DigestAuth $http 1
CkHttp_put_Login $http "username"
CkHttp_put_Password $http "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.

# {
#   "cloudProviderConfig": {
#     "aws": {
#       "roleId": "1a234bcd5e67f89a12b345c6",
#       "testS3Bucket": "user-metric-data-bucket"
#     }
#   },
#   "dataProcessRegion": {
#     "cloudProvider": "AWS",
#     "region": "OREGON_USA"
#   }
# }

set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "cloudProviderConfig.aws.roleId" "1a234bcd5e67f89a12b345c6"
CkJsonObject_UpdateString $json "cloudProviderConfig.aws.testS3Bucket" "user-metric-data-bucket"
CkJsonObject_UpdateString $json "dataProcessRegion.cloudProvider" "AWS"
CkJsonObject_UpdateString $json "dataProcessRegion.region" "OREGON_USA"

set sbRequestBody [new_CkStringBuilder]

CkJsonObject_EmitSb $json $sbRequestBody

# resp is a CkHttpResponse
set resp [CkHttp_PTextSb $http "PATCH" "https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/dataLakes/{{DATA-LAKE-NAME}}" $sbRequestBody "utf-8" "application/json" 0 0]
if {[CkHttp_get_LastMethodSuccess $http] == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkJsonObject $json
    delete_CkStringBuilder $sbRequestBody
    exit
}

puts [CkHttpResponse_get_StatusCode $resp]
puts [CkHttpResponse_bodyStr $resp]
delete_CkHttpResponse $resp


delete_CkHttp $http
delete_CkJsonObject $json
delete_CkStringBuilder $sbRequestBody

Curl Command

curl -X PATCH
	--digest -u 'username:password'
	-d '{
    "cloudProviderConfig": {
        "aws": {
            "roleId": "1a234bcd5e67f89a12b345c6",
            "testS3Bucket": "user-metric-data-bucket"
        }
    },
    "dataProcessRegion": {
        "cloudProvider": "AWS",
        "region": "OREGON_USA"
    }
}'
https://domain.com/api/atlas/{{version}}/groups/{{ProjectID}}/dataLakes/{{DATA-LAKE-NAME}}

Postman Collection Item JSON

{
  "name": "Update One Data Lake",
  "request": {
    "method": "PATCH",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"cloudProviderConfig\": {\n        \"aws\": {\n            \"roleId\": \"1a234bcd5e67f89a12b345c6\",\n            \"testS3Bucket\": \"user-metric-data-bucket\"\n        }\n    },\n    \"dataProcessRegion\": {\n        \"cloudProvider\": \"AWS\",\n        \"region\": \"OREGON_USA\"\n    }\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{base_url}}/api/atlas/{{version}}/groups/{{ProjectID}}/dataLakes/{{DATA-LAKE-NAME}}",
      "host": [
        "{{base_url}}"
      ],
      "path": [
        "api",
        "atlas",
        "{{version}}",
        "groups",
        "{{ProjectID}}",
        "dataLakes",
        "{{DATA-LAKE-NAME}}"
      ]
    },
    "description": "https://docs.mongodb.com/datalake/reference/api/dataLakes-update-one-tenant/"
  },
  "response": [
  ]
}