UpdateReplicationConfiguration Ruby Example
require 'chilkat'
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
rest = Chilkat::CkRest.new()
authAws = Chilkat::CkAuthAws.new()
authAws.put_AccessKey("AWS_ACCESS_KEY")
authAws.put_SecretKey("AWS_SECRET_KEY")
# Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
authAws.put_Region("us-west-2")
authAws.put_ServiceName("drs")
# SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.SetAuthAws(authAws)
# URL: https://drs.us-west-2.amazonaws.com/
# Use the same region as specified above.
success = rest.Connect("drs.us-west-2.amazonaws.com",443,true,true)
if (success != true)
print "ConnectFailReason: " + rest.get_ConnectFailReason().to_s() + "\n";
print rest.lastErrorText() + "\n";
exit
end
# The following code creates the JSON request body.
# The JSON created by this code is shown below.
# Use this online tool to generate code from sample JSON:
# Generate Code to Create JSON
json = Chilkat::CkJsonObject.new()
json.UpdateInt("associateDefaultSecurityGroup",123)
json.UpdateInt("bandwidthThrottling",123)
json.UpdateInt("createPublicIP",123)
json.UpdateString("dataPlaneRouting","string")
json.UpdateString("defaultLargeStagingDiskType","string")
json.UpdateString("ebsEncryption","string")
json.UpdateString("ebsEncryptionKeyArn","string")
json.UpdateString("name","string")
json.UpdateInt("pitPolicy[0].enabled",123)
json.UpdateInt("pitPolicy[0].interval",123)
json.UpdateInt("pitPolicy[0].retentionDuration",123)
json.UpdateInt("pitPolicy[0].ruleID",123)
json.UpdateString("pitPolicy[0].units","string")
json.UpdateString("replicatedDisks[0].deviceName","string")
json.UpdateInt("replicatedDisks[0].iops",123)
json.UpdateInt("replicatedDisks[0].isBootDisk",123)
json.UpdateString("replicatedDisks[0].stagingDiskType","string")
json.UpdateInt("replicatedDisks[0].throughput",123)
json.UpdateString("replicationServerInstanceType","string")
json.UpdateString("replicationServersSecurityGroupsIDs[0]","string")
json.UpdateString("sourceServerID","string")
json.UpdateString("stagingAreaSubnetId","string")
json.UpdateString("stagingAreaTags.string","string")
json.UpdateInt("useDedicatedReplicationServer",123)
# The JSON request body created by the above code:
# {
# "associateDefaultSecurityGroup": boolean,
# "bandwidthThrottling": number,
# "createPublicIP": boolean,
# "dataPlaneRouting": "string",
# "defaultLargeStagingDiskType": "string",
# "ebsEncryption": "string",
# "ebsEncryptionKeyArn": "string",
# "name": "string",
# "pitPolicy": [
# {
# "enabled": boolean,
# "interval": number,
# "retentionDuration": number,
# "ruleID": number,
# "units": "string"
# }
# ],
# "replicatedDisks": [
# {
# "deviceName": "string",
# "iops": number,
# "isBootDisk": boolean,
# "stagingDiskType": "string",
# "throughput": number
# }
# ],
# "replicationServerInstanceType": "string",
# "replicationServersSecurityGroupsIDs": [
# "string"
# ],
# "sourceServerID": "string",
# "stagingAreaSubnetId": "string",
# "stagingAreaTags": {
# "string": "string"
# },
# "useDedicatedReplicationServer": boolean
# }
rest.AddHeader("Content-Type","application/x-amz-json-1.1")
rest.AddHeader("X-Amz-Target","UpdateReplicationConfiguration")
sbRequestBody = Chilkat::CkStringBuilder.new()
json.EmitSb(sbRequestBody)
sbResponseBody = Chilkat::CkStringBuilder.new()
success = rest.FullRequestSb("POST","/UpdateReplicationConfiguration",sbRequestBody,sbResponseBody)
if (success != true)
print rest.lastErrorText() + "\n";
exit
end
respStatusCode = rest.get_ResponseStatusCode()
print "response status code = " + respStatusCode.to_s() + "\n";
if (respStatusCode != 200)
print "Response Header:" + "\n";
print rest.responseHeader() + "\n";
print "Response Body:" + "\n";
print sbResponseBody.getAsString() + "\n";
exit
end
jResp = Chilkat::CkJsonObject.new()
jResp.LoadSb(sbResponseBody)
# The following code parses the JSON response.
# A sample JSON response is shown below the sample code.
# Use this online tool to generate parsing code from sample JSON:
# Generate Parsing Code from JSON
associateDefaultSecurityGroup = jResp.IntOf("associateDefaultSecurityGroup")
bandwidthThrottling = jResp.IntOf("bandwidthThrottling")
createPublicIP = jResp.IntOf("createPublicIP")
dataPlaneRouting = jResp.stringOf("dataPlaneRouting")
defaultLargeStagingDiskType = jResp.stringOf("defaultLargeStagingDiskType")
ebsEncryption = jResp.stringOf("ebsEncryption")
ebsEncryptionKeyArn = jResp.stringOf("ebsEncryptionKeyArn")
name = jResp.stringOf("name")
replicationServerInstanceType = jResp.stringOf("replicationServerInstanceType")
sourceServerID = jResp.stringOf("sourceServerID")
stagingAreaSubnetId = jResp.stringOf("stagingAreaSubnetId")
v_String = jResp.stringOf("stagingAreaTags.string")
useDedicatedReplicationServer = jResp.IntOf("useDedicatedReplicationServer")
i = 0
count_i = jResp.SizeOfArray("pitPolicy")
while i < count_i
jResp.put_I(i)
enabled = jResp.IntOf("pitPolicy[i].enabled")
interval = jResp.IntOf("pitPolicy[i].interval")
retentionDuration = jResp.IntOf("pitPolicy[i].retentionDuration")
ruleID = jResp.IntOf("pitPolicy[i].ruleID")
units = jResp.stringOf("pitPolicy[i].units")
i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("replicatedDisks")
while i < count_i
jResp.put_I(i)
deviceName = jResp.stringOf("replicatedDisks[i].deviceName")
iops = jResp.IntOf("replicatedDisks[i].iops")
isBootDisk = jResp.IntOf("replicatedDisks[i].isBootDisk")
stagingDiskType = jResp.stringOf("replicatedDisks[i].stagingDiskType")
throughput = jResp.IntOf("replicatedDisks[i].throughput")
i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("replicationServersSecurityGroupsIDs")
while i < count_i
jResp.put_I(i)
strVal = jResp.stringOf("replicationServersSecurityGroupsIDs[i]")
i = i + 1
end
# A sample JSON response body parsed by the above code:
# {
# "associateDefaultSecurityGroup": boolean,
# "bandwidthThrottling": number,
# "createPublicIP": boolean,
# "dataPlaneRouting": "string",
# "defaultLargeStagingDiskType": "string",
# "ebsEncryption": "string",
# "ebsEncryptionKeyArn": "string",
# "name": "string",
# "pitPolicy": [
# {
# "enabled": boolean,
# "interval": number,
# "retentionDuration": number,
# "ruleID": number,
# "units": "string"
# }
# ],
# "replicatedDisks": [
# {
# "deviceName": "string",
# "iops": number,
# "isBootDisk": boolean,
# "stagingDiskType": "string",
# "throughput": number
# }
# ],
# "replicationServerInstanceType": "string",
# "replicationServersSecurityGroupsIDs": [
# "string"
# ],
# "sourceServerID": "string",
# "stagingAreaSubnetId": "string",
# "stagingAreaTags": {
# "string": "string"
# },
# "useDedicatedReplicationServer": boolean
# }