DomainProps

class aws_cdk.aws_elasticsearch.DomainProps(*, version, access_policies=None, advanced_options=None, automated_snapshot_start_hour=None, capacity=None, cognito_kibana_auth=None, custom_endpoint=None, domain_name=None, ebs=None, enable_version_upgrade=None, encryption_at_rest=None, enforce_https=None, fine_grained_access_control=None, logging=None, node_to_node_encryption=None, removal_policy=None, security_groups=None, tls_security_policy=None, use_unsigned_basic_auth=None, vpc=None, vpc_subnets=None, zone_awareness=None)

Bases: object

Properties for an AWS Elasticsearch Domain.

Parameters
  • version (ElasticsearchVersion) – The Elasticsearch version that your domain will leverage.

  • access_policies (Optional[Sequence[PolicyStatement]]) – Domain Access policies. Default: - No access policies.

  • advanced_options (Optional[Mapping[str, str]]) – Additional options to specify for the Amazon ES domain. Default: - no advanced options are specified

  • automated_snapshot_start_hour (Union[int, float, None]) – The hour in UTC during which the service takes an automated daily snapshot of the indices in the Amazon ES domain. Only applies for Elasticsearch versions below 5.3. Default: - Hourly automated snapshots not used

  • capacity (Optional[CapacityConfig]) – The cluster capacity configuration for the Amazon ES domain. Default: - 1 r5.large.elasticsearch data node; no dedicated master nodes.

  • cognito_kibana_auth (Optional[CognitoOptions]) – Configures Amazon ES to use Amazon Cognito authentication for Kibana. Default: - Cognito not used for authentication to Kibana.

  • custom_endpoint (Optional[CustomEndpointOptions]) – To configure a custom domain configure these options. If you specify a Route53 hosted zone it will create a CNAME record and use DNS validation for the certificate Default: - no custom domain endpoint will be configured

  • domain_name (Optional[str]) – Enforces a particular physical domain name. Default: - A name will be auto-generated.

  • ebs (Optional[EbsOptions]) – The configurations of Amazon Elastic Block Store (Amazon EBS) volumes that are attached to data nodes in the Amazon ES domain. For more information, see [Configuring EBS-based Storage] (https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-createupdatedomains.html#es-createdomain-configure-ebs) in the Amazon Elasticsearch Service Developer Guide. Default: - 10 GiB General Purpose (SSD) volumes per node.

  • enable_version_upgrade (Optional[bool]) – To upgrade an Amazon ES domain to a new version of Elasticsearch rather than replacing the entire domain resource, use the EnableVersionUpgrade update policy. Default: - false

  • encryption_at_rest (Optional[EncryptionAtRestOptions]) – Encryption at rest options for the cluster. Default: - No encryption at rest

  • enforce_https (Optional[bool]) – True to require that all traffic to the domain arrive over HTTPS. Default: - false

  • fine_grained_access_control (Optional[AdvancedSecurityOptions]) – Specifies options for fine-grained access control. Requires Elasticsearch version 6.7 or later. Enabling fine-grained access control also requires encryption of data at rest and node-to-node encryption, along with enforced HTTPS. Default: - fine-grained access control is disabled

  • logging (Optional[LoggingOptions]) – Configuration log publishing configuration options. Default: - No logs are published

  • node_to_node_encryption (Optional[bool]) – Specify true to enable node to node encryption. Requires Elasticsearch version 6.0 or later. Default: - Node to node encryption is not enabled.

  • removal_policy (Optional[RemovalPolicy]) – Policy to apply when the domain is removed from the stack. Default: RemovalPolicy.RETAIN

  • security_groups (Optional[Sequence[ISecurityGroup]]) – The list of security groups that are associated with the VPC endpoints for the domain. Only used if vpc is specified. Default: - One new security group is created.

  • tls_security_policy (Optional[TLSSecurityPolicy]) – The minimum TLS version required for traffic to the domain. Default: - TLSSecurityPolicy.TLS_1_0

  • use_unsigned_basic_auth (Optional[bool]) – Configures the domain so that unsigned basic auth is enabled. If no master user is provided a default master user with username admin and a dynamically generated password stored in KMS is created. The password can be retrieved by getting masterUserPassword from the domain instance. Setting this to true will also add an access policy that allows unsigned access, enable node to node encryption, encryption at rest. If conflicting settings are encountered (like disabling encryption at rest) enabling this setting will cause a failure. Default: - false

  • vpc (Optional[IVpc]) – Place the domain inside this VPC. Default: - Domain is not placed in a VPC.

  • vpc_subnets (Optional[Sequence[SubnetSelection]]) – The specific vpc subnets the domain will be placed in. You must provide one subnet for each Availability Zone that your domain uses. For example, you must specify three subnet IDs for a three Availability Zone domain. Only used if vpc is specified. Default: - All private subnets.

  • zone_awareness (Optional[ZoneAwarenessConfig]) – The cluster zone awareness configuration for the Amazon ES domain. Default: - no zone awareness (1 AZ)

Attributes

access_policies

Domain Access policies.

Default
  • No access policies.

Return type

Optional[List[PolicyStatement]]

advanced_options

Additional options to specify for the Amazon ES domain.

Default
  • no advanced options are specified

See

https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-createupdatedomains.html#es-createdomain-configure-advanced-options

Return type

Optional[Mapping[str, str]]

automated_snapshot_start_hour

The hour in UTC during which the service takes an automated daily snapshot of the indices in the Amazon ES domain.

Only applies for Elasticsearch versions below 5.3.

Default
  • Hourly automated snapshots not used

Return type

Union[int, float, None]

capacity

The cluster capacity configuration for the Amazon ES domain.

Default
  • 1 r5.large.elasticsearch data node; no dedicated master nodes.

Return type

Optional[CapacityConfig]

cognito_kibana_auth

Configures Amazon ES to use Amazon Cognito authentication for Kibana.

Default
  • Cognito not used for authentication to Kibana.

Return type

Optional[CognitoOptions]

custom_endpoint

To configure a custom domain configure these options.

If you specify a Route53 hosted zone it will create a CNAME record and use DNS validation for the certificate

Default
  • no custom domain endpoint will be configured

Return type

Optional[CustomEndpointOptions]

domain_name

Enforces a particular physical domain name.

Default
  • A name will be auto-generated.

Return type

Optional[str]

ebs

The configurations of Amazon Elastic Block Store (Amazon EBS) volumes that are attached to data nodes in the Amazon ES domain.

For more information, see [Configuring EBS-based Storage] (https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-createupdatedomains.html#es-createdomain-configure-ebs) in the Amazon Elasticsearch Service Developer Guide.

Default
  • 10 GiB General Purpose (SSD) volumes per node.

Return type

Optional[EbsOptions]

enable_version_upgrade

To upgrade an Amazon ES domain to a new version of Elasticsearch rather than replacing the entire domain resource, use the EnableVersionUpgrade update policy.

Default
  • false

See

https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-updatepolicy.html#cfn-attributes-updatepolicy-upgradeelasticsearchdomain

Return type

Optional[bool]

encryption_at_rest

Encryption at rest options for the cluster.

Default
  • No encryption at rest

Return type

Optional[EncryptionAtRestOptions]

enforce_https

True to require that all traffic to the domain arrive over HTTPS.

Default
  • false

Return type

Optional[bool]

fine_grained_access_control

Specifies options for fine-grained access control.

Requires Elasticsearch version 6.7 or later. Enabling fine-grained access control also requires encryption of data at rest and node-to-node encryption, along with enforced HTTPS.

Default
  • fine-grained access control is disabled

Return type

Optional[AdvancedSecurityOptions]

logging

Configuration log publishing configuration options.

Default
  • No logs are published

Return type

Optional[LoggingOptions]

node_to_node_encryption

Specify true to enable node to node encryption.

Requires Elasticsearch version 6.0 or later.

Default
  • Node to node encryption is not enabled.

Return type

Optional[bool]

removal_policy

Policy to apply when the domain is removed from the stack.

Default

RemovalPolicy.RETAIN

Return type

Optional[RemovalPolicy]

security_groups

The list of security groups that are associated with the VPC endpoints for the domain.

Only used if vpc is specified.

Default
  • One new security group is created.

See

https://docs.aws.amazon.com/vpc/latest/userguide/VPC_SecurityGroups.html

Return type

Optional[List[ISecurityGroup]]

tls_security_policy

The minimum TLS version required for traffic to the domain.

Default
  • TLSSecurityPolicy.TLS_1_0

Return type

Optional[TLSSecurityPolicy]

use_unsigned_basic_auth

Configures the domain so that unsigned basic auth is enabled.

If no master user is provided a default master user with username admin and a dynamically generated password stored in KMS is created. The password can be retrieved by getting masterUserPassword from the domain instance.

Setting this to true will also add an access policy that allows unsigned access, enable node to node encryption, encryption at rest. If conflicting settings are encountered (like disabling encryption at rest) enabling this setting will cause a failure.

Default
  • false

Return type

Optional[bool]

version

The Elasticsearch version that your domain will leverage.

Return type

ElasticsearchVersion

vpc

Place the domain inside this VPC.

Default
  • Domain is not placed in a VPC.

See

https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-vpc.html

Return type

Optional[IVpc]

vpc_subnets

The specific vpc subnets the domain will be placed in.

You must provide one subnet for each Availability Zone that your domain uses. For example, you must specify three subnet IDs for a three Availability Zone domain.

Only used if vpc is specified.

Default
  • All private subnets.

See

https://docs.aws.amazon.com/vpc/latest/userguide/VPC_Subnets.html

Return type

Optional[List[SubnetSelection]]

zone_awareness

The cluster zone awareness configuration for the Amazon ES domain.

Default
  • no zone awareness (1 AZ)

Return type

Optional[ZoneAwarenessConfig]