/// <summary> /// Unmarshaller the response from the service to the response class. /// </summary> /// <param name="context"></param> /// <returns></returns> public override AmazonWebServiceResponse Unmarshall(JsonUnmarshallerContext context) { ListFirewallRuleGroupsResponse response = new ListFirewallRuleGroupsResponse(); context.Read(); int targetDepth = context.CurrentDepth; while (context.ReadAtDepth(targetDepth)) { if (context.TestExpression("FirewallRuleGroups", targetDepth)) { var unmarshaller = new ListUnmarshaller <FirewallRuleGroupMetadata, FirewallRuleGroupMetadataUnmarshaller>(FirewallRuleGroupMetadataUnmarshaller.Instance); response.FirewallRuleGroups = unmarshaller.Unmarshall(context); continue; } if (context.TestExpression("NextToken", targetDepth)) { var unmarshaller = StringUnmarshaller.Instance; response.NextToken = unmarshaller.Unmarshall(context); continue; } } return(response); }
public override void Invoke(AWSCredentials creds, RegionEndpoint region, int maxItems) { AmazonRoute53ResolverConfig config = new AmazonRoute53ResolverConfig(); config.RegionEndpoint = region; ConfigureClient(config); AmazonRoute53ResolverClient client = new AmazonRoute53ResolverClient(creds, config); ListFirewallRuleGroupsResponse resp = new ListFirewallRuleGroupsResponse(); do { ListFirewallRuleGroupsRequest req = new ListFirewallRuleGroupsRequest { NextToken = resp.NextToken , MaxResults = maxItems }; resp = client.ListFirewallRuleGroups(req); CheckError(resp.HttpStatusCode, "200"); foreach (var obj in resp.FirewallRuleGroups) { AddObject(obj); } }while (!string.IsNullOrEmpty(resp.NextToken)); }