DescribeOrganizationConfigRules Powershell Example
Add-Type -Path "C:\chilkat\ChilkatDotNet47-9.5.0-x64\ChilkatDotNet47.dll"
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
$rest = New-Object Chilkat.Rest
$authAws = New-Object Chilkat.AuthAws
$authAws.AccessKey = "AWS_ACCESS_KEY"
$authAws.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.Region = "us-west-2"
$authAws.ServiceName = "config"
# SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
$rest.SetAuthAws($authAws)
# URL: https://config.us-west-2.amazonaws.com/
# Use the same region as specified above.
$success = $rest.Connect("config.us-west-2.amazonaws.com",443,$true,$true)
if ($success -ne $true) {
$("ConnectFailReason: " + $rest.ConnectFailReason)
$($rest.LastErrorText)
exit
}
# 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 = New-Object Chilkat.JsonObject
$json.UpdateInt("Limit",123)
$json.UpdateString("NextToken","string")
$json.UpdateString("OrganizationConfigRuleNames[0]","string")
# The JSON request body created by the above code:
# {
# "Limit": number,
# "NextToken": "string",
# "OrganizationConfigRuleNames": [
# "string"
# ]
# }
$rest.AddHeader("Content-Type","application/x-amz-json-1.1")
$rest.AddHeader("X-Amz-Target","StarlingDoveService.DescribeOrganizationConfigRules")
$sbRequestBody = New-Object Chilkat.StringBuilder
$json.EmitSb($sbRequestBody)
$sbResponseBody = New-Object Chilkat.StringBuilder
$success = $rest.FullRequestSb("POST","/",$sbRequestBody,$sbResponseBody)
if ($success -ne $true) {
$($rest.LastErrorText)
exit
}
$respStatusCode = $rest.ResponseStatusCode
$("response status code = " + $respStatusCode)
if ($respStatusCode -ne 200) {
$("Response Header:")
$($rest.ResponseHeader)
$("Response Body:")
$($sbResponseBody.GetAsString())
exit
}
$jResp = New-Object Chilkat.JsonObject
$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
$NextToken = $jResp.StringOf("NextToken")
$i = 0
$count_i = $jResp.SizeOfArray("OrganizationConfigRules")
while ($i -lt $count_i) {
$jResp.I = $i
$LastUpdateTime = $jResp.IntOf("OrganizationConfigRules[i].LastUpdateTime")
$OrganizationConfigRuleArn = $jResp.StringOf("OrganizationConfigRules[i].OrganizationConfigRuleArn")
$OrganizationConfigRuleName = $jResp.StringOf("OrganizationConfigRules[i].OrganizationConfigRuleName")
$Description = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.Description")
$InputParameters = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.InputParameters")
$MaximumExecutionFrequency = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.MaximumExecutionFrequency")
$PolicyRuntime = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.PolicyRuntime")
$ResourceIdScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.ResourceIdScope")
$TagKeyScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.TagKeyScope")
$TagValueScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.TagValueScope")
$OrganizationCustomRuleMetadataDescription = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.Description")
$OrganizationCustomRuleMetadataInputParameters = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.InputParameters")
$LambdaFunctionArn = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.LambdaFunctionArn")
$OrganizationCustomRuleMetadataMaximumExecutionFrequency = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.MaximumExecutionFrequency")
$OrganizationCustomRuleMetadataResourceIdScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.ResourceIdScope")
$OrganizationCustomRuleMetadataTagKeyScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.TagKeyScope")
$OrganizationCustomRuleMetadataTagValueScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.TagValueScope")
$OrganizationManagedRuleMetadataDescription = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.Description")
$OrganizationManagedRuleMetadataInputParameters = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.InputParameters")
$OrganizationManagedRuleMetadataMaximumExecutionFrequency = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.MaximumExecutionFrequency")
$OrganizationManagedRuleMetadataResourceIdScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.ResourceIdScope")
$RuleIdentifier = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.RuleIdentifier")
$OrganizationManagedRuleMetadataTagKeyScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.TagKeyScope")
$OrganizationManagedRuleMetadataTagValueScope = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.TagValueScope")
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].ExcludedAccounts")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].ExcludedAccounts[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.DebugLogDeliveryAccounts")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.DebugLogDeliveryAccounts[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.OrganizationConfigRuleTriggerTypes")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.OrganizationConfigRuleTriggerTypes[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.ResourceTypesScope")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomPolicyRuleMetadata.ResourceTypesScope[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.OrganizationConfigRuleTriggerTypes")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.OrganizationConfigRuleTriggerTypes[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.ResourceTypesScope")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationCustomRuleMetadata.ResourceTypesScope[j]")
$j = $j + 1
}
$j = 0
$count_j = $jResp.SizeOfArray("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.ResourceTypesScope")
while ($j -lt $count_j) {
$jResp.J = $j
$strVal = $jResp.StringOf("OrganizationConfigRules[i].OrganizationManagedRuleMetadata.ResourceTypesScope[j]")
$j = $j + 1
}
$i = $i + 1
}
# A sample JSON response body parsed by the above code:
# {
# "NextToken": "string",
# "OrganizationConfigRules": [
# {
# "ExcludedAccounts": [
# "string"
# ],
# "LastUpdateTime": number,
# "OrganizationConfigRuleArn": "string",
# "OrganizationConfigRuleName": "string",
# "OrganizationCustomPolicyRuleMetadata": {
# "DebugLogDeliveryAccounts": [
# "string"
# ],
# "Description": "string",
# "InputParameters": "string",
# "MaximumExecutionFrequency": "string",
# "OrganizationConfigRuleTriggerTypes": [
# "string"
# ],
# "PolicyRuntime": "string",
# "ResourceIdScope": "string",
# "ResourceTypesScope": [
# "string"
# ],
# "TagKeyScope": "string",
# "TagValueScope": "string"
# },
# "OrganizationCustomRuleMetadata": {
# "Description": "string",
# "InputParameters": "string",
# "LambdaFunctionArn": "string",
# "MaximumExecutionFrequency": "string",
# "OrganizationConfigRuleTriggerTypes": [
# "string"
# ],
# "ResourceIdScope": "string",
# "ResourceTypesScope": [
# "string"
# ],
# "TagKeyScope": "string",
# "TagValueScope": "string"
# },
# "OrganizationManagedRuleMetadata": {
# "Description": "string",
# "InputParameters": "string",
# "MaximumExecutionFrequency": "string",
# "ResourceIdScope": "string",
# "ResourceTypesScope": [
# "string"
# ],
# "RuleIdentifier": "string",
# "TagKeyScope": "string",
# "TagValueScope": "string"
# }
# }
# ]
# }