aws-cdk-lib.aws_opensearchservice.DomainProps

interface DomainProps

LanguageType name
.NETAmazon.CDK.AWS.OpenSearchService.DomainProps
Gogithub.com/aws/aws-cdk-go/awscdk/v2/awsopensearchservice#DomainProps
Javasoftware.amazon.awscdk.services.opensearchservice.DomainProps
Pythonaws_cdk.aws_opensearchservice.DomainProps
TypeScript (source)aws-cdk-lib » aws_opensearchservice » DomainProps

Properties for an Amazon OpenSearch Service domain.

Example

const domain = new Domain(this, 'Domain', {
  version: EngineVersion.OPENSEARCH_1_0,
  ebs: {
    volumeSize: 100,
    volumeType: ec2.EbsDeviceVolumeType.GENERAL_PURPOSE_SSD,
  },
  nodeToNodeEncryption: true,
  encryptionAtRest: {
    enabled: true,
  },
});

Properties

NameTypeDescription
versionEngineVersionThe Elasticsearch/OpenSearch version that your domain will leverage.
accessPolicies?PolicyStatement[]Domain access policies.
advancedOptions?{ [string]: string }Additional options to specify for the Amazon OpenSearch Service domain.
automatedSnapshotStartHour?numberThe hour in UTC during which the service takes an automated daily snapshot of the indices in the Amazon OpenSearch Service domain.
capacity?CapacityConfigThe cluster capacity configuration for the Amazon OpenSearch Service domain.
cognitoDashboardsAuth?CognitoOptionsConfigures Amazon OpenSearch Service to use Amazon Cognito authentication for OpenSearch Dashboards.
customEndpoint?CustomEndpointOptionsTo configure a custom domain configure these options.
domainName?stringEnforces a particular physical domain name.
ebs?EbsOptionsThe configurations of Amazon Elastic Block Store (Amazon EBS) volumes that are attached to data nodes in the Amazon OpenSearch Service domain.
enableVersionUpgrade?booleanTo upgrade an Amazon OpenSearch Service domain to a new version, rather than replacing the entire domain resource, use the EnableVersionUpgrade update policy.
encryptionAtRest?EncryptionAtRestOptionsEncryption at rest options for the cluster.
enforceHttps?booleanTrue to require that all traffic to the domain arrive over HTTPS.
fineGrainedAccessControl?AdvancedSecurityOptionsSpecifies options for fine-grained access control.
logging?LoggingOptionsConfiguration log publishing configuration options.
nodeToNodeEncryption?booleanSpecify true to enable node to node encryption.
removalPolicy?RemovalPolicyPolicy to apply when the domain is removed from the stack.
securityGroups?ISecurityGroup[]The list of security groups that are associated with the VPC endpoints for the domain.
tlsSecurityPolicy?TLSSecurityPolicyThe minimum TLS version required for traffic to the domain.
useUnsignedBasicAuth?booleanConfigures the domain so that unsigned basic auth is enabled.
vpc?IVpcPlace the domain inside this VPC.
vpcSubnets?SubnetSelection[]The specific vpc subnets the domain will be placed in.
zoneAwareness?ZoneAwarenessConfigThe cluster zone awareness configuration for the Amazon OpenSearch Service domain.

version

Type: EngineVersion

The Elasticsearch/OpenSearch version that your domain will leverage.


accessPolicies?

Type: PolicyStatement[] (optional, default: No access policies.)

Domain access policies.


advancedOptions?

Type: { [string]: string } (optional, default: no advanced options are specified)

Additional options to specify for the Amazon OpenSearch Service domain.

See also: https://docs.aws.amazon.com/opensearch-service/latest/developerguide/createupdatedomains.html#createdomain-configure-advanced-options


automatedSnapshotStartHour?

Type: number (optional, default: Hourly automated snapshots not used)

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

Only applies for Elasticsearch versions below 5.3.


capacity?

Type: CapacityConfig (optional, default: 1 r5.large.search data node; no dedicated master nodes.)

The cluster capacity configuration for the Amazon OpenSearch Service domain.


cognitoDashboardsAuth?

Type: CognitoOptions (optional, default: Cognito not used for authentication to OpenSearch Dashboards.)

Configures Amazon OpenSearch Service to use Amazon Cognito authentication for OpenSearch Dashboards.


customEndpoint?

Type: CustomEndpointOptions (optional, default: no custom domain endpoint will be configured)

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


domainName?

Type: string (optional, default: A name will be auto-generated.)

Enforces a particular physical domain name.


ebs?

Type: EbsOptions (optional, default: 10 GiB General Purpose (SSD) volumes per node.)

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


enableVersionUpgrade?

Type: boolean (optional, default: false)

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

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


encryptionAtRest?

Type: EncryptionAtRestOptions (optional, default: No encryption at rest)

Encryption at rest options for the cluster.


enforceHttps?

Type: boolean (optional, default: false)

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


fineGrainedAccessControl?

Type: AdvancedSecurityOptions (optional, default: fine-grained access control is disabled)

Specifies options for fine-grained access control.

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


logging?

Type: LoggingOptions (optional, default: No logs are published)

Configuration log publishing configuration options.


nodeToNodeEncryption?

Type: boolean (optional, default: Node to node encryption is not enabled.)

Specify true to enable node to node encryption.

Requires Elasticsearch version 6.0 or later or OpenSearch version 1.0 or later.


removalPolicy?

Type: RemovalPolicy (optional, default: RemovalPolicy.RETAIN)

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


securityGroups?

Type: ISecurityGroup[] (optional, default: One new security group is created.)

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

Only used if vpc is specified.

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


tlsSecurityPolicy?

Type: TLSSecurityPolicy (optional, default: TLSSecurityPolicy.TLS_1_0)

The minimum TLS version required for traffic to the domain.


useUnsignedBasicAuth?

Type: boolean (optional, default: false)

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.


vpc?

Type: IVpc (optional, default: Domain is not placed in a VPC.)

Place the domain inside this VPC.

See also: https://docs.aws.amazon.com/opensearch-service/latest/developerguide/vpc.html


vpcSubnets?

Type: SubnetSelection[] (optional, default: All private 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.

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


zoneAwareness?

Type: ZoneAwarenessConfig (optional, default: no zone awareness (1 AZ))

The cluster zone awareness configuration for the Amazon OpenSearch Service domain.