/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include The details of the VPC of the Amazon ES destination.See Also:
* AWS
* API Reference
The IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline const Aws::VectorThe IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline bool SubnetIdsHasBeenSet() const { return m_subnetIdsHasBeenSet; } /** *The IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline void SetSubnetIds(const Aws::VectorThe IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline void SetSubnetIds(Aws::VectorThe IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline VpcConfigurationDescription& WithSubnetIds(const Aws::VectorThe IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline VpcConfigurationDescription& WithSubnetIds(Aws::VectorThe IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline VpcConfigurationDescription& AddSubnetIds(const Aws::String& value) { m_subnetIdsHasBeenSet = true; m_subnetIds.push_back(value); return *this; } /** *The IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline VpcConfigurationDescription& AddSubnetIds(Aws::String&& value) { m_subnetIdsHasBeenSet = true; m_subnetIds.push_back(std::move(value)); return *this; } /** *The IDs of the subnets that Kinesis Data Firehose uses to create ENIs in the * VPC of the Amazon ES destination. Make sure that the routing tables and inbound * and outbound rules allow traffic to flow from the subnets whose IDs are * specified here to the subnets that have the destination Amazon ES endpoints. * Kinesis Data Firehose creates at least one ENI in each of the subnets that are * specified here. Do not delete or modify these ENIs.
The number of ENIs * that Kinesis Data Firehose creates in the subnets specified here scales up and * down automatically based on throughput. To enable Kinesis Data Firehose to scale * up the number of ENIs to match throughput, ensure that you have sufficient * quota. To help you calculate the quota you need, assume that Kinesis Data * Firehose can create up to three ENIs for this delivery stream for each of the * subnets specified here. For more information about ENI quota, see Network * Interfaces in the Amazon VPC Quotas topic.
*/ inline VpcConfigurationDescription& AddSubnetIds(const char* value) { m_subnetIdsHasBeenSet = true; m_subnetIds.push_back(value); return *this; } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline const Aws::String& GetRoleARN() const{ return m_roleARN; } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline bool RoleARNHasBeenSet() const { return m_roleARNHasBeenSet; } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline void SetRoleARN(const Aws::String& value) { m_roleARNHasBeenSet = true; m_roleARN = value; } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline void SetRoleARN(Aws::String&& value) { m_roleARNHasBeenSet = true; m_roleARN = std::move(value); } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline void SetRoleARN(const char* value) { m_roleARNHasBeenSet = true; m_roleARN.assign(value); } /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline VpcConfigurationDescription& WithRoleARN(const Aws::String& value) { SetRoleARN(value); return *this;} /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline VpcConfigurationDescription& WithRoleARN(Aws::String&& value) { SetRoleARN(std::move(value)); return *this;} /** *The ARN of the IAM role that the delivery stream uses to create endpoints in * the destination VPC. You can use your existing Kinesis Data Firehose delivery * role or you can specify a new role. In either case, make sure that the role * trusts the Kinesis Data Firehose service principal and that it grants the * following permissions:
ec2:DescribeVpcs
ec2:DescribeVpcAttribute
* ec2:DescribeSubnets
* ec2:DescribeSecurityGroups
* ec2:DescribeNetworkInterfaces
* ec2:CreateNetworkInterface
* ec2:CreateNetworkInterfacePermission
* ec2:DeleteNetworkInterface
If you revoke these * permissions after you create the delivery stream, Kinesis Data Firehose can't * scale out by creating more ENIs when necessary. You might therefore see a * degradation in performance.
*/ inline VpcConfigurationDescription& WithRoleARN(const char* value) { SetRoleARN(value); return *this;} /** *The IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline const Aws::VectorThe IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline bool SecurityGroupIdsHasBeenSet() const { return m_securityGroupIdsHasBeenSet; } /** *The IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline void SetSecurityGroupIds(const Aws::VectorThe IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline void SetSecurityGroupIds(Aws::VectorThe IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline VpcConfigurationDescription& WithSecurityGroupIds(const Aws::VectorThe IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline VpcConfigurationDescription& WithSecurityGroupIds(Aws::VectorThe IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline VpcConfigurationDescription& AddSecurityGroupIds(const Aws::String& value) { m_securityGroupIdsHasBeenSet = true; m_securityGroupIds.push_back(value); return *this; } /** *The IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline VpcConfigurationDescription& AddSecurityGroupIds(Aws::String&& value) { m_securityGroupIdsHasBeenSet = true; m_securityGroupIds.push_back(std::move(value)); return *this; } /** *The IDs of the security groups that Kinesis Data Firehose uses when it * creates ENIs in the VPC of the Amazon ES destination. You can use the same * security group that the Amazon ES domain uses or different ones. If you specify * different security groups, ensure that they allow outbound HTTPS traffic to the * Amazon ES domain's security group. Also ensure that the Amazon ES domain's * security group allows HTTPS traffic from the security groups specified here. If * you use the same security group for both your delivery stream and the Amazon ES * domain, make sure the security group inbound rule allows HTTPS traffic. For more * information about security group rules, see Security * group rules in the Amazon VPC documentation.
*/ inline VpcConfigurationDescription& AddSecurityGroupIds(const char* value) { m_securityGroupIdsHasBeenSet = true; m_securityGroupIds.push_back(value); return *this; } /** *The ID of the Amazon ES destination's VPC.
*/ inline const Aws::String& GetVpcId() const{ return m_vpcId; } /** *The ID of the Amazon ES destination's VPC.
*/ inline bool VpcIdHasBeenSet() const { return m_vpcIdHasBeenSet; } /** *The ID of the Amazon ES destination's VPC.
*/ inline void SetVpcId(const Aws::String& value) { m_vpcIdHasBeenSet = true; m_vpcId = value; } /** *The ID of the Amazon ES destination's VPC.
*/ inline void SetVpcId(Aws::String&& value) { m_vpcIdHasBeenSet = true; m_vpcId = std::move(value); } /** *The ID of the Amazon ES destination's VPC.
*/ inline void SetVpcId(const char* value) { m_vpcIdHasBeenSet = true; m_vpcId.assign(value); } /** *The ID of the Amazon ES destination's VPC.
*/ inline VpcConfigurationDescription& WithVpcId(const Aws::String& value) { SetVpcId(value); return *this;} /** *The ID of the Amazon ES destination's VPC.
*/ inline VpcConfigurationDescription& WithVpcId(Aws::String&& value) { SetVpcId(std::move(value)); return *this;} /** *The ID of the Amazon ES destination's VPC.
*/ inline VpcConfigurationDescription& WithVpcId(const char* value) { SetVpcId(value); return *this;} private: Aws::Vector