UpdateRuleGroup unicodeCpp Example
#include <CkRestW.h>
#include <CkAuthAwsW.h>
#include <CkJsonObjectW.h>
#include <CkStringBuilderW.h>
void ChilkatSample(void)
{
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkRestW rest;
bool success;
CkAuthAwsW authAws;
authAws.put_AccessKey(L"AWS_ACCESS_KEY");
authAws.put_SecretKey(L"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(L"us-west-2");
authAws.put_ServiceName(L"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(L"network-firewall.us-west-2.amazonaws.com",443,true,true);
if (success != true) {
wprintf(L"ConnectFailReason: %d\n",rest.get_ConnectFailReason());
wprintf(L"%s\n",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
CkJsonObjectW json;
json.UpdateString(L"Description",L"string");
json.UpdateInt(L"DryRun",123);
json.UpdateString(L"EncryptionConfiguration.KeyId",L"string");
json.UpdateString(L"EncryptionConfiguration.Type",L"string");
json.UpdateString(L"RuleGroup.RulesSource.RulesSourceList.GeneratedRulesType",L"string");
json.UpdateString(L"RuleGroup.RulesSource.RulesSourceList.Targets[0]",L"string");
json.UpdateString(L"RuleGroup.RulesSource.RulesSourceList.TargetTypes[0]",L"string");
json.UpdateString(L"RuleGroup.RulesSource.RulesString",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Action",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.Destination",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.DestinationPort",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.Direction",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.Protocol",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.Source",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].Header.SourcePort",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].RuleOptions[0].Keyword",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatefulRules[0].RuleOptions[0].Settings[0]",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.CustomActions[0].ActionDefinition.PublishMetricAction.Dimensions[0].Value",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.CustomActions[0].ActionName",L"string");
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].Priority",123);
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.Actions[0]",L"string");
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.DestinationPorts[0].FromPort",123);
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.DestinationPorts[0].ToPort",123);
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Destinations[0].AddressDefinition",L"string");
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Protocols[0]",number);ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
ERROR: Undefined variable(number)
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.SourcePorts[0].FromPort",123);
json.UpdateInt(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.SourcePorts[0].ToPort",123);
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.Sources[0].AddressDefinition",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.TCPFlags[0].Flags[0]",L"string");
json.UpdateString(L"RuleGroup.RulesSource.StatelessRulesAndCustomActions.StatelessRules[0].RuleDefinition.MatchAttributes.TCPFlags[0].Masks[0]",L"string");
json.UpdateString(L"RuleGroup.RuleVariables.IPSets.string.Definition[0]",L"string");
json.UpdateString(L"RuleGroup.RuleVariables.PortSets.string.Definition[0]",L"string");
json.UpdateString(L"RuleGroup.StatefulRuleOptions.RuleOrder",L"string");
json.UpdateString(L"RuleGroupArn",L"string");
json.UpdateString(L"RuleGroupName",L"string");
json.UpdateString(L"Rules",L"string");
json.UpdateString(L"SourceMetadata.SourceArn",L"string");
json.UpdateString(L"SourceMetadata.SourceUpdateToken",L"string");
json.UpdateString(L"Type",L"string");
json.UpdateString(L"UpdateToken",L"string");
// The JSON request body created by the above code:
// {
// "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"
// }
// },
// "RuleGroupArn": "string",
// "RuleGroupName": "string",
// "Rules": "string",
// "SourceMetadata": {
// "SourceArn": "string",
// "SourceUpdateToken": "string"
// },
// "Type": "string",
// "UpdateToken": "string"
// }
rest.AddHeader(L"Content-Type",L"application/x-amz-json-1.0");
rest.AddHeader(L"X-Amz-Target",L"NetworkFirewall_20201112.UpdateRuleGroup");
CkStringBuilderW sbRequestBody;
json.EmitSb(sbRequestBody);
CkStringBuilderW sbResponseBody;
success = rest.FullRequestSb(L"POST",L"/",sbRequestBody,sbResponseBody);
if (success != true) {
wprintf(L"%s\n",rest.lastErrorText());
return;
}
int respStatusCode = rest.get_ResponseStatusCode();
wprintf(L"response status code = %d\n",respStatusCode);
if (respStatusCode != 200) {
wprintf(L"Response Header:\n");
wprintf(L"%s\n",rest.responseHeader());
wprintf(L"Response Body:\n");
wprintf(L"%s\n",sbResponseBody.getAsString());
return;
}
CkJsonObjectW jResp;
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
// Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
// See this example explaining how this memory should be used: const char * functions.
const wchar_t *Key = 0;
const wchar_t *Value = 0;
int Capacity = jResp.IntOf(L"RuleGroupResponse.Capacity");
int ConsumedCapacity = jResp.IntOf(L"RuleGroupResponse.ConsumedCapacity");
const wchar_t *Description = jResp.stringOf(L"RuleGroupResponse.Description");
const wchar_t *KeyId = jResp.stringOf(L"RuleGroupResponse.EncryptionConfiguration.KeyId");
const wchar_t *v_Type = jResp.stringOf(L"RuleGroupResponse.EncryptionConfiguration.Type");
int LastModifiedTime = jResp.IntOf(L"RuleGroupResponse.LastModifiedTime");
int NumberOfAssociations = jResp.IntOf(L"RuleGroupResponse.NumberOfAssociations");
const wchar_t *RuleGroupArn = jResp.stringOf(L"RuleGroupResponse.RuleGroupArn");
const wchar_t *RuleGroupId = jResp.stringOf(L"RuleGroupResponse.RuleGroupId");
const wchar_t *RuleGroupName = jResp.stringOf(L"RuleGroupResponse.RuleGroupName");
const wchar_t *RuleGroupStatus = jResp.stringOf(L"RuleGroupResponse.RuleGroupStatus");
const wchar_t *SnsTopic = jResp.stringOf(L"RuleGroupResponse.SnsTopic");
const wchar_t *SourceArn = jResp.stringOf(L"RuleGroupResponse.SourceMetadata.SourceArn");
const wchar_t *SourceUpdateToken = jResp.stringOf(L"RuleGroupResponse.SourceMetadata.SourceUpdateToken");
const wchar_t *RuleGroupResponseType = jResp.stringOf(L"RuleGroupResponse.Type");
const wchar_t *UpdateToken = jResp.stringOf(L"UpdateToken");
int i = 0;
int count_i = jResp.SizeOfArray(L"RuleGroupResponse.Tags");
while (i < count_i) {
jResp.put_I(i);
Key = jResp.stringOf(L"RuleGroupResponse.Tags[i].Key");
Value = jResp.stringOf(L"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"
// }
}