aws-sdk-networkfirewall 1.61.0 → 1.63.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -655,6 +655,9 @@ module Aws::NetworkFirewall
655
655
  # To retrieve information about firewalls, use ListFirewalls and
656
656
  # DescribeFirewall.
657
657
  #
658
+ # To generate a report on the last 30 days of traffic monitored by a
659
+ # firewall, use StartAnalysisReport.
660
+ #
658
661
  # @option params [required, String] :firewall_name
659
662
  # The descriptive name of the firewall. You can't change the name of a
660
663
  # firewall after you create it.
@@ -663,13 +666,13 @@ module Aws::NetworkFirewall
663
666
  # The Amazon Resource Name (ARN) of the FirewallPolicy that you want to
664
667
  # use for the firewall.
665
668
  #
666
- # @option params [required, String] :vpc_id
669
+ # @option params [String] :vpc_id
667
670
  # The unique identifier of the VPC where Network Firewall should create
668
671
  # the firewall.
669
672
  #
670
673
  # You can't change this setting after you create the firewall.
671
674
  #
672
- # @option params [required, Array<Types::SubnetMapping>] :subnet_mappings
675
+ # @option params [Array<Types::SubnetMapping>] :subnet_mappings
673
676
  # The public subnets to use for your Network Firewall firewalls. Each
674
677
  # subnet must belong to a different Availability Zone in the VPC.
675
678
  # Network Firewall creates a firewall endpoint in each subnet.
@@ -705,6 +708,10 @@ module Aws::NetworkFirewall
705
708
  # A complex type that contains settings for encryption of your firewall
706
709
  # resources.
707
710
  #
711
+ # @option params [Array<String>] :enabled_analysis_types
712
+ # An optional setting indicating the specific traffic analysis types to
713
+ # enable on the firewall.
714
+ #
708
715
  # @return [Types::CreateFirewallResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
709
716
  #
710
717
  # * {Types::CreateFirewallResponse#firewall #firewall} => Types::Firewall
@@ -715,8 +722,8 @@ module Aws::NetworkFirewall
715
722
  # resp = client.create_firewall({
716
723
  # firewall_name: "ResourceName", # required
717
724
  # firewall_policy_arn: "ResourceArn", # required
718
- # vpc_id: "VpcId", # required
719
- # subnet_mappings: [ # required
725
+ # vpc_id: "VpcId",
726
+ # subnet_mappings: [
720
727
  # {
721
728
  # subnet_id: "CollectionMember_String", # required
722
729
  # ip_address_type: "DUALSTACK", # accepts DUALSTACK, IPV4, IPV6
@@ -736,6 +743,7 @@ module Aws::NetworkFirewall
736
743
  # key_id: "KeyId",
737
744
  # type: "CUSTOMER_KMS", # required, accepts CUSTOMER_KMS, AWS_OWNED_KMS_KEY
738
745
  # },
746
+ # enabled_analysis_types: ["TLS_SNI"], # accepts TLS_SNI, HTTP_HOST
739
747
  # })
740
748
  #
741
749
  # @example Response structure
@@ -757,6 +765,8 @@ module Aws::NetworkFirewall
757
765
  # resp.firewall.tags[0].value #=> String
758
766
  # resp.firewall.encryption_configuration.key_id #=> String
759
767
  # resp.firewall.encryption_configuration.type #=> String, one of "CUSTOMER_KMS", "AWS_OWNED_KMS_KEY"
768
+ # resp.firewall.enabled_analysis_types #=> Array
769
+ # resp.firewall.enabled_analysis_types[0] #=> String, one of "TLS_SNI", "HTTP_HOST"
760
770
  # resp.firewall_status.status #=> String, one of "PROVISIONING", "DELETING", "READY"
761
771
  # resp.firewall_status.configuration_sync_state_summary #=> String, one of "PENDING", "IN_SYNC", "CAPACITY_CONSTRAINED"
762
772
  # resp.firewall_status.sync_states #=> Hash
@@ -1453,6 +1463,8 @@ module Aws::NetworkFirewall
1453
1463
  # resp.firewall.tags[0].value #=> String
1454
1464
  # resp.firewall.encryption_configuration.key_id #=> String
1455
1465
  # resp.firewall.encryption_configuration.type #=> String, one of "CUSTOMER_KMS", "AWS_OWNED_KMS_KEY"
1466
+ # resp.firewall.enabled_analysis_types #=> Array
1467
+ # resp.firewall.enabled_analysis_types[0] #=> String, one of "TLS_SNI", "HTTP_HOST"
1456
1468
  # resp.firewall_status.status #=> String, one of "PROVISIONING", "DELETING", "READY"
1457
1469
  # resp.firewall_status.configuration_sync_state_summary #=> String, one of "PENDING", "IN_SYNC", "CAPACITY_CONSTRAINED"
1458
1470
  # resp.firewall_status.sync_states #=> Hash
@@ -1724,6 +1736,8 @@ module Aws::NetworkFirewall
1724
1736
  # resp.firewall.tags[0].value #=> String
1725
1737
  # resp.firewall.encryption_configuration.key_id #=> String
1726
1738
  # resp.firewall.encryption_configuration.type #=> String, one of "CUSTOMER_KMS", "AWS_OWNED_KMS_KEY"
1739
+ # resp.firewall.enabled_analysis_types #=> Array
1740
+ # resp.firewall.enabled_analysis_types[0] #=> String, one of "TLS_SNI", "HTTP_HOST"
1727
1741
  # resp.firewall_status.status #=> String, one of "PROVISIONING", "DELETING", "READY"
1728
1742
  # resp.firewall_status.configuration_sync_state_summary #=> String, one of "PENDING", "IN_SYNC", "CAPACITY_CONSTRAINED"
1729
1743
  # resp.firewall_status.sync_states #=> Hash
@@ -1825,6 +1839,69 @@ module Aws::NetworkFirewall
1825
1839
  req.send_request(options)
1826
1840
  end
1827
1841
 
1842
+ # Returns key information about a specific flow operation.
1843
+ #
1844
+ # @option params [required, String] :firewall_arn
1845
+ # The Amazon Resource Name (ARN) of the firewall.
1846
+ #
1847
+ # @option params [String] :availability_zone
1848
+ # The ID of the Availability Zone where the firewall is located. For
1849
+ # example, `us-east-2a`.
1850
+ #
1851
+ # Defines the scope a flow operation. You can use up to 20 filters to
1852
+ # configure a single flow operation.
1853
+ #
1854
+ # @option params [required, String] :flow_operation_id
1855
+ # A unique identifier for the flow operation. This ID is returned in the
1856
+ # responses to start and list commands. You provide to describe
1857
+ # commands.
1858
+ #
1859
+ # @return [Types::DescribeFlowOperationResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
1860
+ #
1861
+ # * {Types::DescribeFlowOperationResponse#firewall_arn #firewall_arn} => String
1862
+ # * {Types::DescribeFlowOperationResponse#availability_zone #availability_zone} => String
1863
+ # * {Types::DescribeFlowOperationResponse#flow_operation_id #flow_operation_id} => String
1864
+ # * {Types::DescribeFlowOperationResponse#flow_operation_type #flow_operation_type} => String
1865
+ # * {Types::DescribeFlowOperationResponse#flow_operation_status #flow_operation_status} => String
1866
+ # * {Types::DescribeFlowOperationResponse#status_message #status_message} => String
1867
+ # * {Types::DescribeFlowOperationResponse#flow_request_timestamp #flow_request_timestamp} => Time
1868
+ # * {Types::DescribeFlowOperationResponse#flow_operation #flow_operation} => Types::FlowOperation
1869
+ #
1870
+ # @example Request syntax with placeholder values
1871
+ #
1872
+ # resp = client.describe_flow_operation({
1873
+ # firewall_arn: "ResourceArn", # required
1874
+ # availability_zone: "AvailabilityZone",
1875
+ # flow_operation_id: "FlowOperationId", # required
1876
+ # })
1877
+ #
1878
+ # @example Response structure
1879
+ #
1880
+ # resp.firewall_arn #=> String
1881
+ # resp.availability_zone #=> String
1882
+ # resp.flow_operation_id #=> String
1883
+ # resp.flow_operation_type #=> String, one of "FLOW_FLUSH", "FLOW_CAPTURE"
1884
+ # resp.flow_operation_status #=> String, one of "COMPLETED", "IN_PROGRESS", "FAILED", "COMPLETED_WITH_ERRORS"
1885
+ # resp.status_message #=> String
1886
+ # resp.flow_request_timestamp #=> Time
1887
+ # resp.flow_operation.minimum_flow_age_in_seconds #=> Integer
1888
+ # resp.flow_operation.flow_filters #=> Array
1889
+ # resp.flow_operation.flow_filters[0].source_address.address_definition #=> String
1890
+ # resp.flow_operation.flow_filters[0].destination_address.address_definition #=> String
1891
+ # resp.flow_operation.flow_filters[0].source_port #=> String
1892
+ # resp.flow_operation.flow_filters[0].destination_port #=> String
1893
+ # resp.flow_operation.flow_filters[0].protocols #=> Array
1894
+ # resp.flow_operation.flow_filters[0].protocols[0] #=> String
1895
+ #
1896
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/DescribeFlowOperation AWS API Documentation
1897
+ #
1898
+ # @overload describe_flow_operation(params = {})
1899
+ # @param [Hash] params ({})
1900
+ def describe_flow_operation(params = {}, options = {})
1901
+ req = build_request(:describe_flow_operation, params)
1902
+ req.send_request(options)
1903
+ end
1904
+
1828
1905
  # Returns the logging configuration for the specified firewall.
1829
1906
  #
1830
1907
  # @option params [String] :firewall_arn
@@ -2244,6 +2321,147 @@ module Aws::NetworkFirewall
2244
2321
  req.send_request(options)
2245
2322
  end
2246
2323
 
2324
+ # The results of a `COMPLETED` analysis report generated with
2325
+ # StartAnalysisReport.
2326
+ #
2327
+ # For more information, see AnalysisTypeReportResult.
2328
+ #
2329
+ # @option params [String] :firewall_name
2330
+ # The descriptive name of the firewall. You can't change the name of a
2331
+ # firewall after you create it.
2332
+ #
2333
+ # You must specify the ARN or the name, and you can specify both.
2334
+ #
2335
+ # @option params [required, String] :analysis_report_id
2336
+ # The unique ID of the query that ran when you requested an analysis
2337
+ # report.
2338
+ #
2339
+ # @option params [String] :firewall_arn
2340
+ # The Amazon Resource Name (ARN) of the firewall.
2341
+ #
2342
+ # You must specify the ARN or the name, and you can specify both.
2343
+ #
2344
+ # @option params [String] :next_token
2345
+ # When you request a list of objects with a `MaxResults` setting, if the
2346
+ # number of objects that are still available for retrieval exceeds the
2347
+ # maximum you requested, Network Firewall returns a `NextToken` value in
2348
+ # the response. To retrieve the next batch of objects, use the token
2349
+ # returned from the prior request in your next request.
2350
+ #
2351
+ # @option params [Integer] :max_results
2352
+ # The maximum number of objects that you want Network Firewall to return
2353
+ # for this request. If more objects are available, in the response,
2354
+ # Network Firewall provides a `NextToken` value that you can use in a
2355
+ # subsequent call to get the next batch of objects.
2356
+ #
2357
+ # @return [Types::GetAnalysisReportResultsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2358
+ #
2359
+ # * {Types::GetAnalysisReportResultsResponse#status #status} => String
2360
+ # * {Types::GetAnalysisReportResultsResponse#start_time #start_time} => Time
2361
+ # * {Types::GetAnalysisReportResultsResponse#end_time #end_time} => Time
2362
+ # * {Types::GetAnalysisReportResultsResponse#report_time #report_time} => Time
2363
+ # * {Types::GetAnalysisReportResultsResponse#analysis_type #analysis_type} => String
2364
+ # * {Types::GetAnalysisReportResultsResponse#next_token #next_token} => String
2365
+ # * {Types::GetAnalysisReportResultsResponse#analysis_report_results #analysis_report_results} => Array&lt;Types::AnalysisTypeReportResult&gt;
2366
+ #
2367
+ # The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
2368
+ #
2369
+ # @example Request syntax with placeholder values
2370
+ #
2371
+ # resp = client.get_analysis_report_results({
2372
+ # firewall_name: "ResourceName",
2373
+ # analysis_report_id: "AnalysisReportId", # required
2374
+ # firewall_arn: "ResourceArn",
2375
+ # next_token: "AnalysisReportNextToken",
2376
+ # max_results: 1,
2377
+ # })
2378
+ #
2379
+ # @example Response structure
2380
+ #
2381
+ # resp.status #=> String
2382
+ # resp.start_time #=> Time
2383
+ # resp.end_time #=> Time
2384
+ # resp.report_time #=> Time
2385
+ # resp.analysis_type #=> String, one of "TLS_SNI", "HTTP_HOST"
2386
+ # resp.next_token #=> String
2387
+ # resp.analysis_report_results #=> Array
2388
+ # resp.analysis_report_results[0].protocol #=> String
2389
+ # resp.analysis_report_results[0].first_accessed #=> Time
2390
+ # resp.analysis_report_results[0].last_accessed #=> Time
2391
+ # resp.analysis_report_results[0].domain #=> String
2392
+ # resp.analysis_report_results[0].hits.count #=> Integer
2393
+ # resp.analysis_report_results[0].unique_sources.count #=> Integer
2394
+ #
2395
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/GetAnalysisReportResults AWS API Documentation
2396
+ #
2397
+ # @overload get_analysis_report_results(params = {})
2398
+ # @param [Hash] params ({})
2399
+ def get_analysis_report_results(params = {}, options = {})
2400
+ req = build_request(:get_analysis_report_results, params)
2401
+ req.send_request(options)
2402
+ end
2403
+
2404
+ # Returns a list of all traffic analysis reports generated within the
2405
+ # last 30 days.
2406
+ #
2407
+ # @option params [String] :firewall_name
2408
+ # The descriptive name of the firewall. You can't change the name of a
2409
+ # firewall after you create it.
2410
+ #
2411
+ # You must specify the ARN or the name, and you can specify both.
2412
+ #
2413
+ # @option params [String] :firewall_arn
2414
+ # The Amazon Resource Name (ARN) of the firewall.
2415
+ #
2416
+ # You must specify the ARN or the name, and you can specify both.
2417
+ #
2418
+ # @option params [String] :next_token
2419
+ # When you request a list of objects with a `MaxResults` setting, if the
2420
+ # number of objects that are still available for retrieval exceeds the
2421
+ # maximum you requested, Network Firewall returns a `NextToken` value in
2422
+ # the response. To retrieve the next batch of objects, use the token
2423
+ # returned from the prior request in your next request.
2424
+ #
2425
+ # @option params [Integer] :max_results
2426
+ # The maximum number of objects that you want Network Firewall to return
2427
+ # for this request. If more objects are available, in the response,
2428
+ # Network Firewall provides a `NextToken` value that you can use in a
2429
+ # subsequent call to get the next batch of objects.
2430
+ #
2431
+ # @return [Types::ListAnalysisReportsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2432
+ #
2433
+ # * {Types::ListAnalysisReportsResponse#analysis_reports #analysis_reports} => Array&lt;Types::AnalysisReport&gt;
2434
+ # * {Types::ListAnalysisReportsResponse#next_token #next_token} => String
2435
+ #
2436
+ # The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
2437
+ #
2438
+ # @example Request syntax with placeholder values
2439
+ #
2440
+ # resp = client.list_analysis_reports({
2441
+ # firewall_name: "ResourceName",
2442
+ # firewall_arn: "ResourceArn",
2443
+ # next_token: "PaginationToken",
2444
+ # max_results: 1,
2445
+ # })
2446
+ #
2447
+ # @example Response structure
2448
+ #
2449
+ # resp.analysis_reports #=> Array
2450
+ # resp.analysis_reports[0].analysis_report_id #=> String
2451
+ # resp.analysis_reports[0].analysis_type #=> String, one of "TLS_SNI", "HTTP_HOST"
2452
+ # resp.analysis_reports[0].report_time #=> Time
2453
+ # resp.analysis_reports[0].status #=> String
2454
+ # resp.next_token #=> String
2455
+ #
2456
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/ListAnalysisReports AWS API Documentation
2457
+ #
2458
+ # @overload list_analysis_reports(params = {})
2459
+ # @param [Hash] params ({})
2460
+ def list_analysis_reports(params = {}, options = {})
2461
+ req = build_request(:list_analysis_reports, params)
2462
+ req.send_request(options)
2463
+ end
2464
+
2247
2465
  # Retrieves the metadata for the firewall policies that you have
2248
2466
  # defined. Depending on your setting for max results and the number of
2249
2467
  # firewall policies, a single call might not return the full list.
@@ -2347,6 +2565,170 @@ module Aws::NetworkFirewall
2347
2565
  req.send_request(options)
2348
2566
  end
2349
2567
 
2568
+ # Returns the results of a specific flow operation.
2569
+ #
2570
+ # Flow operations let you manage the flows tracked in the flow table,
2571
+ # also known as the firewall table.
2572
+ #
2573
+ # A flow is network traffic that is monitored by a firewall, either by
2574
+ # stateful or stateless rules. For traffic to be considered part of a
2575
+ # flow, it must share Destination, DestinationPort, Direction, Protocol,
2576
+ # Source, and SourcePort.
2577
+ #
2578
+ # @option params [required, String] :firewall_arn
2579
+ # The Amazon Resource Name (ARN) of the firewall.
2580
+ #
2581
+ # @option params [required, String] :flow_operation_id
2582
+ # A unique identifier for the flow operation. This ID is returned in the
2583
+ # responses to start and list commands. You provide to describe
2584
+ # commands.
2585
+ #
2586
+ # @option params [String] :next_token
2587
+ # When you request a list of objects with a `MaxResults` setting, if the
2588
+ # number of objects that are still available for retrieval exceeds the
2589
+ # maximum you requested, Network Firewall returns a `NextToken` value in
2590
+ # the response. To retrieve the next batch of objects, use the token
2591
+ # returned from the prior request in your next request.
2592
+ #
2593
+ # @option params [Integer] :max_results
2594
+ # The maximum number of objects that you want Network Firewall to return
2595
+ # for this request. If more objects are available, in the response,
2596
+ # Network Firewall provides a `NextToken` value that you can use in a
2597
+ # subsequent call to get the next batch of objects.
2598
+ #
2599
+ # @option params [String] :availability_zone
2600
+ # The ID of the Availability Zone where the firewall is located. For
2601
+ # example, `us-east-2a`.
2602
+ #
2603
+ # Defines the scope a flow operation. You can use up to 20 filters to
2604
+ # configure a single flow operation.
2605
+ #
2606
+ # @return [Types::ListFlowOperationResultsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2607
+ #
2608
+ # * {Types::ListFlowOperationResultsResponse#firewall_arn #firewall_arn} => String
2609
+ # * {Types::ListFlowOperationResultsResponse#availability_zone #availability_zone} => String
2610
+ # * {Types::ListFlowOperationResultsResponse#flow_operation_id #flow_operation_id} => String
2611
+ # * {Types::ListFlowOperationResultsResponse#flow_operation_status #flow_operation_status} => String
2612
+ # * {Types::ListFlowOperationResultsResponse#status_message #status_message} => String
2613
+ # * {Types::ListFlowOperationResultsResponse#flow_request_timestamp #flow_request_timestamp} => Time
2614
+ # * {Types::ListFlowOperationResultsResponse#flows #flows} => Array&lt;Types::Flow&gt;
2615
+ # * {Types::ListFlowOperationResultsResponse#next_token #next_token} => String
2616
+ #
2617
+ # The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
2618
+ #
2619
+ # @example Request syntax with placeholder values
2620
+ #
2621
+ # resp = client.list_flow_operation_results({
2622
+ # firewall_arn: "ResourceArn", # required
2623
+ # flow_operation_id: "FlowOperationId", # required
2624
+ # next_token: "PaginationToken",
2625
+ # max_results: 1,
2626
+ # availability_zone: "AvailabilityZone",
2627
+ # })
2628
+ #
2629
+ # @example Response structure
2630
+ #
2631
+ # resp.firewall_arn #=> String
2632
+ # resp.availability_zone #=> String
2633
+ # resp.flow_operation_id #=> String
2634
+ # resp.flow_operation_status #=> String, one of "COMPLETED", "IN_PROGRESS", "FAILED", "COMPLETED_WITH_ERRORS"
2635
+ # resp.status_message #=> String
2636
+ # resp.flow_request_timestamp #=> Time
2637
+ # resp.flows #=> Array
2638
+ # resp.flows[0].source_address.address_definition #=> String
2639
+ # resp.flows[0].destination_address.address_definition #=> String
2640
+ # resp.flows[0].source_port #=> String
2641
+ # resp.flows[0].destination_port #=> String
2642
+ # resp.flows[0].protocol #=> String
2643
+ # resp.flows[0].age #=> Integer
2644
+ # resp.flows[0].packet_count #=> Integer
2645
+ # resp.flows[0].byte_count #=> Integer
2646
+ # resp.next_token #=> String
2647
+ #
2648
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/ListFlowOperationResults AWS API Documentation
2649
+ #
2650
+ # @overload list_flow_operation_results(params = {})
2651
+ # @param [Hash] params ({})
2652
+ def list_flow_operation_results(params = {}, options = {})
2653
+ req = build_request(:list_flow_operation_results, params)
2654
+ req.send_request(options)
2655
+ end
2656
+
2657
+ # Returns a list of all flow operations ran in a specific firewall. You
2658
+ # can optionally narrow the request scope by specifying the operation
2659
+ # type or Availability Zone associated with a firewall's flow
2660
+ # operations.
2661
+ #
2662
+ # Flow operations let you manage the flows tracked in the flow table,
2663
+ # also known as the firewall table.
2664
+ #
2665
+ # A flow is network traffic that is monitored by a firewall, either by
2666
+ # stateful or stateless rules. For traffic to be considered part of a
2667
+ # flow, it must share Destination, DestinationPort, Direction, Protocol,
2668
+ # Source, and SourcePort.
2669
+ #
2670
+ # @option params [required, String] :firewall_arn
2671
+ # The Amazon Resource Name (ARN) of the firewall.
2672
+ #
2673
+ # @option params [String] :availability_zone
2674
+ # The ID of the Availability Zone where the firewall is located. For
2675
+ # example, `us-east-2a`.
2676
+ #
2677
+ # Defines the scope a flow operation. You can use up to 20 filters to
2678
+ # configure a single flow operation.
2679
+ #
2680
+ # @option params [String] :flow_operation_type
2681
+ # An optional string that defines whether any or all operation types are
2682
+ # returned.
2683
+ #
2684
+ # @option params [String] :next_token
2685
+ # When you request a list of objects with a `MaxResults` setting, if the
2686
+ # number of objects that are still available for retrieval exceeds the
2687
+ # maximum you requested, Network Firewall returns a `NextToken` value in
2688
+ # the response. To retrieve the next batch of objects, use the token
2689
+ # returned from the prior request in your next request.
2690
+ #
2691
+ # @option params [Integer] :max_results
2692
+ # The maximum number of objects that you want Network Firewall to return
2693
+ # for this request. If more objects are available, in the response,
2694
+ # Network Firewall provides a `NextToken` value that you can use in a
2695
+ # subsequent call to get the next batch of objects.
2696
+ #
2697
+ # @return [Types::ListFlowOperationsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2698
+ #
2699
+ # * {Types::ListFlowOperationsResponse#flow_operations #flow_operations} => Array&lt;Types::FlowOperationMetadata&gt;
2700
+ # * {Types::ListFlowOperationsResponse#next_token #next_token} => String
2701
+ #
2702
+ # The returned {Seahorse::Client::Response response} is a pageable response and is Enumerable. For details on usage see {Aws::PageableResponse PageableResponse}.
2703
+ #
2704
+ # @example Request syntax with placeholder values
2705
+ #
2706
+ # resp = client.list_flow_operations({
2707
+ # firewall_arn: "ResourceArn", # required
2708
+ # availability_zone: "AvailabilityZone",
2709
+ # flow_operation_type: "FLOW_FLUSH", # accepts FLOW_FLUSH, FLOW_CAPTURE
2710
+ # next_token: "PaginationToken",
2711
+ # max_results: 1,
2712
+ # })
2713
+ #
2714
+ # @example Response structure
2715
+ #
2716
+ # resp.flow_operations #=> Array
2717
+ # resp.flow_operations[0].flow_operation_id #=> String
2718
+ # resp.flow_operations[0].flow_operation_type #=> String, one of "FLOW_FLUSH", "FLOW_CAPTURE"
2719
+ # resp.flow_operations[0].flow_request_timestamp #=> Time
2720
+ # resp.flow_operations[0].flow_operation_status #=> String, one of "COMPLETED", "IN_PROGRESS", "FAILED", "COMPLETED_WITH_ERRORS"
2721
+ # resp.next_token #=> String
2722
+ #
2723
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/ListFlowOperations AWS API Documentation
2724
+ #
2725
+ # @overload list_flow_operations(params = {})
2726
+ # @param [Hash] params ({})
2727
+ def list_flow_operations(params = {}, options = {})
2728
+ req = build_request(:list_flow_operations, params)
2729
+ req.send_request(options)
2730
+ end
2731
+
2350
2732
  # Retrieves the metadata for the rule groups that you have defined.
2351
2733
  # Depending on your setting for max results and the number of rule
2352
2734
  # groups, a single call might not return the full list.
@@ -2593,6 +2975,206 @@ module Aws::NetworkFirewall
2593
2975
  req.send_request(options)
2594
2976
  end
2595
2977
 
2978
+ # Generates a traffic analysis report for the timeframe and traffic type
2979
+ # you specify.
2980
+ #
2981
+ # For information on the contents of a traffic analysis report, see
2982
+ # AnalysisReport.
2983
+ #
2984
+ # @option params [String] :firewall_name
2985
+ # The descriptive name of the firewall. You can't change the name of a
2986
+ # firewall after you create it.
2987
+ #
2988
+ # You must specify the ARN or the name, and you can specify both.
2989
+ #
2990
+ # @option params [String] :firewall_arn
2991
+ # The Amazon Resource Name (ARN) of the firewall.
2992
+ #
2993
+ # You must specify the ARN or the name, and you can specify both.
2994
+ #
2995
+ # @option params [required, String] :analysis_type
2996
+ # The type of traffic that will be used to generate a report.
2997
+ #
2998
+ # @return [Types::StartAnalysisReportResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2999
+ #
3000
+ # * {Types::StartAnalysisReportResponse#analysis_report_id #analysis_report_id} => String
3001
+ #
3002
+ # @example Request syntax with placeholder values
3003
+ #
3004
+ # resp = client.start_analysis_report({
3005
+ # firewall_name: "ResourceName",
3006
+ # firewall_arn: "ResourceArn",
3007
+ # analysis_type: "TLS_SNI", # required, accepts TLS_SNI, HTTP_HOST
3008
+ # })
3009
+ #
3010
+ # @example Response structure
3011
+ #
3012
+ # resp.analysis_report_id #=> String
3013
+ #
3014
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/StartAnalysisReport AWS API Documentation
3015
+ #
3016
+ # @overload start_analysis_report(params = {})
3017
+ # @param [Hash] params ({})
3018
+ def start_analysis_report(params = {}, options = {})
3019
+ req = build_request(:start_analysis_report, params)
3020
+ req.send_request(options)
3021
+ end
3022
+
3023
+ # Begins capturing the flows in a firewall, according to the filters you
3024
+ # define. Captures are similar, but not identical to snapshots. Capture
3025
+ # operations provide visibility into flows that are not closed and are
3026
+ # tracked by a firewall's flow table. Unlike snapshots, captures are a
3027
+ # time-boxed view.
3028
+ #
3029
+ # A flow is network traffic that is monitored by a firewall, either by
3030
+ # stateful or stateless rules. For traffic to be considered part of a
3031
+ # flow, it must share Destination, DestinationPort, Direction, Protocol,
3032
+ # Source, and SourcePort.
3033
+ #
3034
+ # <note markdown="1"> To avoid encountering operation limits, you should avoid starting
3035
+ # captures with broad filters, like wide IP ranges. Instead, we
3036
+ # recommend you define more specific criteria with `FlowFilters`, like
3037
+ # narrow IP ranges, ports, or protocols.
3038
+ #
3039
+ # </note>
3040
+ #
3041
+ # @option params [required, String] :firewall_arn
3042
+ # The Amazon Resource Name (ARN) of the firewall.
3043
+ #
3044
+ # @option params [String] :availability_zone
3045
+ # The ID of the Availability Zone where the firewall is located. For
3046
+ # example, `us-east-2a`.
3047
+ #
3048
+ # Defines the scope a flow operation. You can use up to 20 filters to
3049
+ # configure a single flow operation.
3050
+ #
3051
+ # @option params [Integer] :minimum_flow_age_in_seconds
3052
+ # The reqested `FlowOperation` ignores flows with an age (in seconds)
3053
+ # lower than `MinimumFlowAgeInSeconds`. You provide this for start
3054
+ # commands.
3055
+ #
3056
+ # <note markdown="1"> We recommend setting this value to at least 1 minute (60 seconds) to
3057
+ # reduce chance of capturing flows that are not yet established.
3058
+ #
3059
+ # </note>
3060
+ #
3061
+ # @option params [required, Array<Types::FlowFilter>] :flow_filters
3062
+ # Defines the scope a flow operation. You can use up to 20 filters to
3063
+ # configure a single flow operation.
3064
+ #
3065
+ # @return [Types::StartFlowCaptureResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
3066
+ #
3067
+ # * {Types::StartFlowCaptureResponse#firewall_arn #firewall_arn} => String
3068
+ # * {Types::StartFlowCaptureResponse#flow_operation_id #flow_operation_id} => String
3069
+ # * {Types::StartFlowCaptureResponse#flow_operation_status #flow_operation_status} => String
3070
+ #
3071
+ # @example Request syntax with placeholder values
3072
+ #
3073
+ # resp = client.start_flow_capture({
3074
+ # firewall_arn: "ResourceArn", # required
3075
+ # availability_zone: "AvailabilityZone",
3076
+ # minimum_flow_age_in_seconds: 1,
3077
+ # flow_filters: [ # required
3078
+ # {
3079
+ # source_address: {
3080
+ # address_definition: "AddressDefinition", # required
3081
+ # },
3082
+ # destination_address: {
3083
+ # address_definition: "AddressDefinition", # required
3084
+ # },
3085
+ # source_port: "Port",
3086
+ # destination_port: "Port",
3087
+ # protocols: ["ProtocolString"],
3088
+ # },
3089
+ # ],
3090
+ # })
3091
+ #
3092
+ # @example Response structure
3093
+ #
3094
+ # resp.firewall_arn #=> String
3095
+ # resp.flow_operation_id #=> String
3096
+ # resp.flow_operation_status #=> String, one of "COMPLETED", "IN_PROGRESS", "FAILED", "COMPLETED_WITH_ERRORS"
3097
+ #
3098
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/StartFlowCapture AWS API Documentation
3099
+ #
3100
+ # @overload start_flow_capture(params = {})
3101
+ # @param [Hash] params ({})
3102
+ def start_flow_capture(params = {}, options = {})
3103
+ req = build_request(:start_flow_capture, params)
3104
+ req.send_request(options)
3105
+ end
3106
+
3107
+ # Begins the flushing of traffic from the firewall, according to the
3108
+ # filters you define. When the operation starts, impacted flows are
3109
+ # temporarily marked as timed out before the Suricata engine prunes, or
3110
+ # flushes, the flows from the firewall table.
3111
+ #
3112
+ # While the flush completes, impacted flows are processed as midstream
3113
+ # traffic. This may result in a temporary increase in midstream traffic
3114
+ # metrics. We recommend that you double check your stream exception
3115
+ # policy before you perform a flush operation.
3116
+ #
3117
+ # @option params [required, String] :firewall_arn
3118
+ # The Amazon Resource Name (ARN) of the firewall.
3119
+ #
3120
+ # @option params [String] :availability_zone
3121
+ # The ID of the Availability Zone where the firewall is located. For
3122
+ # example, `us-east-2a`.
3123
+ #
3124
+ # Defines the scope a flow operation. You can use up to 20 filters to
3125
+ # configure a single flow operation.
3126
+ #
3127
+ # @option params [Integer] :minimum_flow_age_in_seconds
3128
+ # The reqested `FlowOperation` ignores flows with an age (in seconds)
3129
+ # lower than `MinimumFlowAgeInSeconds`. You provide this for start
3130
+ # commands.
3131
+ #
3132
+ # @option params [required, Array<Types::FlowFilter>] :flow_filters
3133
+ # Defines the scope a flow operation. You can use up to 20 filters to
3134
+ # configure a single flow operation.
3135
+ #
3136
+ # @return [Types::StartFlowFlushResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
3137
+ #
3138
+ # * {Types::StartFlowFlushResponse#firewall_arn #firewall_arn} => String
3139
+ # * {Types::StartFlowFlushResponse#flow_operation_id #flow_operation_id} => String
3140
+ # * {Types::StartFlowFlushResponse#flow_operation_status #flow_operation_status} => String
3141
+ #
3142
+ # @example Request syntax with placeholder values
3143
+ #
3144
+ # resp = client.start_flow_flush({
3145
+ # firewall_arn: "ResourceArn", # required
3146
+ # availability_zone: "AvailabilityZone",
3147
+ # minimum_flow_age_in_seconds: 1,
3148
+ # flow_filters: [ # required
3149
+ # {
3150
+ # source_address: {
3151
+ # address_definition: "AddressDefinition", # required
3152
+ # },
3153
+ # destination_address: {
3154
+ # address_definition: "AddressDefinition", # required
3155
+ # },
3156
+ # source_port: "Port",
3157
+ # destination_port: "Port",
3158
+ # protocols: ["ProtocolString"],
3159
+ # },
3160
+ # ],
3161
+ # })
3162
+ #
3163
+ # @example Response structure
3164
+ #
3165
+ # resp.firewall_arn #=> String
3166
+ # resp.flow_operation_id #=> String
3167
+ # resp.flow_operation_status #=> String, one of "COMPLETED", "IN_PROGRESS", "FAILED", "COMPLETED_WITH_ERRORS"
3168
+ #
3169
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/StartFlowFlush AWS API Documentation
3170
+ #
3171
+ # @overload start_flow_flush(params = {})
3172
+ # @param [Hash] params ({})
3173
+ def start_flow_flush(params = {}, options = {})
3174
+ req = build_request(:start_flow_flush, params)
3175
+ req.send_request(options)
3176
+ end
3177
+
2596
3178
  # Adds the specified tags to the specified resource. Tags are key:value
2597
3179
  # pairs that you can use to categorize and manage your resources, for
2598
3180
  # purposes like billing. For example, you might set the tag key to
@@ -2665,6 +3247,76 @@ module Aws::NetworkFirewall
2665
3247
  req.send_request(options)
2666
3248
  end
2667
3249
 
3250
+ # Enables specific types of firewall analysis on a specific firewall you
3251
+ # define.
3252
+ #
3253
+ # @option params [Array<String>] :enabled_analysis_types
3254
+ # An optional setting indicating the specific traffic analysis types to
3255
+ # enable on the firewall.
3256
+ #
3257
+ # @option params [String] :firewall_arn
3258
+ # The Amazon Resource Name (ARN) of the firewall.
3259
+ #
3260
+ # You must specify the ARN or the name, and you can specify both.
3261
+ #
3262
+ # @option params [String] :firewall_name
3263
+ # The descriptive name of the firewall. You can't change the name of a
3264
+ # firewall after you create it.
3265
+ #
3266
+ # You must specify the ARN or the name, and you can specify both.
3267
+ #
3268
+ # @option params [String] :update_token
3269
+ # An optional token that you can use for optimistic locking. Network
3270
+ # Firewall returns a token to your requests that access the firewall.
3271
+ # The token marks the state of the firewall resource at the time of the
3272
+ # request.
3273
+ #
3274
+ # To make an unconditional change to the firewall, omit the token in
3275
+ # your update request. Without the token, Network Firewall performs your
3276
+ # updates regardless of whether the firewall has changed since you last
3277
+ # retrieved it.
3278
+ #
3279
+ # To make a conditional change to the firewall, provide the token in
3280
+ # your update request. Network Firewall uses the token to ensure that
3281
+ # the firewall hasn't changed since you last retrieved it. If it has
3282
+ # changed, the operation fails with an `InvalidTokenException`. If this
3283
+ # happens, retrieve the firewall again to get a current copy of it with
3284
+ # a new token. Reapply your changes as needed, then try the operation
3285
+ # again using the new token.
3286
+ #
3287
+ # @return [Types::UpdateFirewallAnalysisSettingsResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
3288
+ #
3289
+ # * {Types::UpdateFirewallAnalysisSettingsResponse#enabled_analysis_types #enabled_analysis_types} => Array&lt;String&gt;
3290
+ # * {Types::UpdateFirewallAnalysisSettingsResponse#firewall_arn #firewall_arn} => String
3291
+ # * {Types::UpdateFirewallAnalysisSettingsResponse#firewall_name #firewall_name} => String
3292
+ # * {Types::UpdateFirewallAnalysisSettingsResponse#update_token #update_token} => String
3293
+ #
3294
+ # @example Request syntax with placeholder values
3295
+ #
3296
+ # resp = client.update_firewall_analysis_settings({
3297
+ # enabled_analysis_types: ["TLS_SNI"], # accepts TLS_SNI, HTTP_HOST
3298
+ # firewall_arn: "ResourceArn",
3299
+ # firewall_name: "ResourceName",
3300
+ # update_token: "UpdateToken",
3301
+ # })
3302
+ #
3303
+ # @example Response structure
3304
+ #
3305
+ # resp.enabled_analysis_types #=> Array
3306
+ # resp.enabled_analysis_types[0] #=> String, one of "TLS_SNI", "HTTP_HOST"
3307
+ # resp.firewall_arn #=> String
3308
+ # resp.firewall_name #=> String
3309
+ # resp.update_token #=> String
3310
+ #
3311
+ # @see http://docs.aws.amazon.com/goto/WebAPI/network-firewall-2020-11-12/UpdateFirewallAnalysisSettings AWS API Documentation
3312
+ #
3313
+ # @overload update_firewall_analysis_settings(params = {})
3314
+ # @param [Hash] params ({})
3315
+ def update_firewall_analysis_settings(params = {}, options = {})
3316
+ req = build_request(:update_firewall_analysis_settings, params)
3317
+ req.send_request(options)
3318
+ end
3319
+
2668
3320
  # Modifies the flag, `DeleteProtection`, which indicates whether it is
2669
3321
  # possible to delete the firewall. If the flag is set to `TRUE`, the
2670
3322
  # firewall is protected against deletion. This setting helps protect
@@ -3708,7 +4360,7 @@ module Aws::NetworkFirewall
3708
4360
  tracer: tracer
3709
4361
  )
3710
4362
  context[:gem_name] = 'aws-sdk-networkfirewall'
3711
- context[:gem_version] = '1.61.0'
4363
+ context[:gem_version] = '1.63.0'
3712
4364
  Seahorse::Client::Request.new(handlers, context)
3713
4365
  end
3714
4366