CreateRuleGroup Swift3 Example
func chilkatTest() {
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
let rest = CkoRest()!
var success: Bool
let authAws = CkoAuthAws()!
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 = "network-firewall"
// SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.setAuthAws(authAws)
// URL: https://network-firewall.us-west-2.amazonaws.com/
// Use the same region as specified above.
success = rest.connect("network-firewall.us-west-2.amazonaws.com", port: 443, tls: true, autoReconnect: true)
if success != true {
print("ConnectFailReason: \(rest.connectFailReason.intValue)")
print("\(rest.lastErrorText!)")
return
}
// 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
let json = CkoJsonObject()!
json.updateInt("Capacity", value: 123)
json.update("Description", value: "string")
json.updateInt("DryRun", value: 123)
json.update("EncryptionConfiguration.KeyId", value: "string")
json.update("EncryptionConfiguration.Type", value: "string")
json.update("RuleGroup.RulesSource.RulesSourceList.GeneratedRulesType", value: "string")
json.update("RuleGroup.RulesSource.RulesSourceList.Targets[0]", value: "string")
json.update("RuleGroup.RulesSource.RulesSourceList.TargetTypes[0]", value: "string")
json.update("RuleGroup.RulesSource.RulesString", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Action", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.Destination", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.DestinationPort", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.Direction", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.Protocol", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.Source", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].Header.SourcePort", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].RuleOptions[0].Keyword", value: "string")
json.update("RuleGroup.RulesSource.StatefulRules[0].RuleOptions[0].Settings[0]", value: "string")
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.CustomActions[0].ActionDefinition.PublishMetricAction.Dimensions[0].Value", value: "string")
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.CustomActions[0].ActionName", value: "string")
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].Priority", value: 123)
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.Actions[0]", value: "string")
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.DestinationPorts[0].FromPort", value: 123)
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.DestinationPorts[0].ToPort", value: 123)
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Destinations[0].AddressDefinition", value: "string")
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Protocols[0]", value: number)ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.SourcePorts[0].FromPort", value: 123)
json.updateInt("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.SourcePorts[0].ToPort", value: 123)
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Sources[0].AddressDefinition", value: "string")
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.TCPFlags[0].Flags[0]", value: "string")
json.update("RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.TCPFlags[0].Masks[0]", value: "string")
json.update("RuleGroup.RuleVariables.IPSets.string.Definition[0]", value: "string")
json.update("RuleGroup.RuleVariables.PortSets.string.Definition[0]", value: "string")
json.update("RuleGroup.StatefulRuleOptions.RuleOrder", value: "string")
json.update("RuleGroupName", value: "string")
json.update("Rules", value: "string")
json.update("SourceMetadata.SourceArn", value: "string")
json.update("SourceMetadata.SourceUpdateToken", value: "string")
json.update("Tags[0].Key", value: "string")
json.update("Tags[0].Value", value: "string")
json.update("Type", value: "string")
// The JSON request body created by the above code:
// {
// "Capacity": number,
// "Description": "string",
// "DryRun": boolean,
// "EncryptionConfiguration": {
// "KeyId": "string",
// "Type": "string"
// },
// "RuleGroup": {
// "RulesSource": {
// "RulesSourceList": {
// "GeneratedRulesType": "string",
// "Targets": [
// "string"
// ],
// "TargetTypes": [
// "string"
// ]
// },
// "RulesString": "string",
// "StatefulRules": [
// {
// "Action": "string",
// "Header": {
// "Destination": "string",
// "DestinationPort": "string",
// "Direction": "string",
// "Protocol": "string",
// "Source": "string",
// "SourcePort": "string"
// },
// "RuleOptions": [
// {
// "Keyword": "string",
// "Settings": [
// "string"
// ]
// }
// ]
// }
// ],
// "StatelessRulesAndCustomActions": {
// "CustomActions": [
// {
// "ActionDefinition": {
// "PublishMetricAction": {
// "Dimensions": [
// {
// "Value": "string"
// }
// ]
// }
// },
// "ActionName": "string"
// }
// ],
// "StatelessRules": [
// {
// "Priority": number,
// "RuleDefinition": {
// "Actions": [
// "string"
// ],
// "MatchAttributes": {
// "DestinationPorts": [
// {
// "FromPort": number,
// "ToPort": number
// }
// ],
// "Destinations": [
// {
// "AddressDefinition": "string"
// }
// ],
// "Protocols": [
// number
// ],
// "SourcePorts": [
// {
// "FromPort": number,
// "ToPort": number
// }
// ],
// "Sources": [
// {
// "AddressDefinition": "string"
// }
// ],
// "TCPFlags": [
// {
// "Flags": [
// "string"
// ],
// "Masks": [
// "string"
// ]
// }
// ]
// }
// }
// }
// ]
// }
// },
// "RuleVariables": {
// "IPSets": {
// "string": {
// "Definition": [
// "string"
// ]
// }
// },
// "PortSets": {
// "string": {
// "Definition": [
// "string"
// ]
// }
// }
// },
// "StatefulRuleOptions": {
// "RuleOrder": "string"
// }
// },
// "RuleGroupName": "string",
// "Rules": "string",
// "SourceMetadata": {
// "SourceArn": "string",
// "SourceUpdateToken": "string"
// },
// "Tags": [
// {
// "Key": "string",
// "Value": "string"
// }
// ],
// "Type": "string"
// }
rest.addHeader("Content-Type", value: "application/x-amz-json-1.0")
rest.addHeader("X-Amz-Target", value: "NetworkFirewall_20201112.CreateRuleGroup")
let sbRequestBody = CkoStringBuilder()!
json.emitSb(sbRequestBody)
let sbResponseBody = CkoStringBuilder()!
success = rest.fullRequestSb("POST", uriPath: "/", requestBody: sbRequestBody, responseBody: sbResponseBody)
if success != true {
print("\(rest.lastErrorText!)")
return
}
var respStatusCode: Int = rest.responseStatusCode.intValue
print("response status code = \(respStatusCode)")
if respStatusCode != 200 {
print("Response Header:")
print("\(rest.responseHeader!)")
print("Response Body:")
print("\(sbResponseBody.getAsString()!)")
return
}
let jResp = CkoJsonObject()!
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
var Key: String?
var Value: String?
var Capacity: Int = jResp.int(of: "RuleGroupResponse.Capacity").intValue
var ConsumedCapacity: Int = jResp.int(of: "RuleGroupResponse.ConsumedCapacity").intValue
var Description: String? = jResp.string(of: "RuleGroupResponse.Description")
var KeyId: String? = jResp.string(of: "RuleGroupResponse.EncryptionConfiguration.KeyId")
var v_Type: String? = jResp.string(of: "RuleGroupResponse.EncryptionConfiguration.Type")
var LastModifiedTime: Int = jResp.int(of: "RuleGroupResponse.LastModifiedTime").intValue
var NumberOfAssociations: Int = jResp.int(of: "RuleGroupResponse.NumberOfAssociations").intValue
var RuleGroupArn: String? = jResp.string(of: "RuleGroupResponse.RuleGroupArn")
var RuleGroupId: String? = jResp.string(of: "RuleGroupResponse.RuleGroupId")
var RuleGroupName: String? = jResp.string(of: "RuleGroupResponse.RuleGroupName")
var RuleGroupStatus: String? = jResp.string(of: "RuleGroupResponse.RuleGroupStatus")
var SnsTopic: String? = jResp.string(of: "RuleGroupResponse.SnsTopic")
var SourceArn: String? = jResp.string(of: "RuleGroupResponse.SourceMetadata.SourceArn")
var SourceUpdateToken: String? = jResp.string(of: "RuleGroupResponse.SourceMetadata.SourceUpdateToken")
var RuleGroupResponseType: String? = jResp.string(of: "RuleGroupResponse.Type")
var UpdateToken: String? = jResp.string(of: "UpdateToken")
var i: Int = 0
var count_i: Int = jResp.size(ofArray: "RuleGroupResponse.Tags").intValue
while i < count_i {
jResp.i = i
Key = jResp.string(of: "RuleGroupResponse.Tags[i].Key")
Value = jResp.string(of: "RuleGroupResponse.Tags[i].Value")
i = i + 1
}
// A sample JSON response body parsed by the above code:
// {
// "RuleGroupResponse": {
// "Capacity": number,
// "ConsumedCapacity": number,
// "Description": "string",
// "EncryptionConfiguration": {
// "KeyId": "string",
// "Type": "string"
// },
// "LastModifiedTime": number,
// "NumberOfAssociations": number,
// "RuleGroupArn": "string",
// "RuleGroupId": "string",
// "RuleGroupName": "string",
// "RuleGroupStatus": "string",
// "SnsTopic": "string",
// "SourceMetadata": {
// "SourceArn": "string",
// "SourceUpdateToken": "string"
// },
// "Tags": [
// {
// "Key": "string",
// "Value": "string"
// }
// ],
// "Type": "string"
// },
// "UpdateToken": "string"
// }
}