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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +10 -0
- data/VERSION +1 -1
- data/lib/aws-sdk-networkfirewall/client.rb +657 -5
- data/lib/aws-sdk-networkfirewall/client_api.rb +360 -2
- data/lib/aws-sdk-networkfirewall/types.rb +1024 -21
- data/lib/aws-sdk-networkfirewall.rb +1 -1
- data/sig/client.rbs +175 -3
- data/sig/types.rbs +212 -0
- metadata +2 -2
@@ -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 [
|
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 [
|
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",
|
719
|
-
# subnet_mappings: [
|
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<Types::AnalysisTypeReportResult>
|
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<Types::AnalysisReport>
|
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<Types::Flow>
|
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<Types::FlowOperationMetadata>
|
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<String>
|
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.
|
4363
|
+
context[:gem_version] = '1.63.0'
|
3712
4364
|
Seahorse::Client::Request.new(handlers, context)
|
3713
4365
|
end
|
3714
4366
|
|