package awscdkneptunealpha import ( _jsii_ "github.com/aws/jsii-runtime-go/runtime" "github.com/aws/aws-cdk-go/awscdk/v2" "github.com/aws/aws-cdk-go/awscdk/v2/awscloudwatch" "github.com/aws/aws-cdk-go/awscdk/v2/awsec2" "github.com/aws/aws-cdk-go/awscdk/v2/awsiam" "github.com/aws/aws-cdk-go/awscdkneptunealpha/v2/internal" "github.com/aws/constructs-go/constructs/v10" ) // Create a clustered database with a given number of instances. // Experimental. type IDatabaseCluster interface { awsec2.IConnectable awscdk.IResource // Grant the given identity the specified actions. // See: https://docs.aws.amazon.com/neptune/latest/userguide/iam-dp-actions.html // // Experimental. Grant(grantee awsiam.IGrantable, actions ...*string) awsiam.Grant // Grant the given identity connection access to the database. // Experimental. GrantConnect(grantee awsiam.IGrantable) awsiam.Grant // Return the given named metric associated with this DatabaseCluster instance. // See: https://docs.aws.amazon.com/neptune/latest/userguide/cw-dimensions.html // // Experimental. Metric(metricName *string, props *awscloudwatch.MetricOptions) awscloudwatch.Metric // The endpoint to use for read/write operations. // Experimental. ClusterEndpoint() Endpoint // Identifier of the cluster. // Experimental. ClusterIdentifier() *string // Endpoint to use for load-balanced read-only operations. // Experimental. ClusterReadEndpoint() Endpoint // Resource identifier of the cluster. // Experimental. ClusterResourceIdentifier() *string } // The jsii proxy for IDatabaseCluster type jsiiProxy_IDatabaseCluster struct { internal.Type__awsec2IConnectable internal.Type__awscdkIResource } func (i *jsiiProxy_IDatabaseCluster) Grant(grantee awsiam.IGrantable, actions ...*string) awsiam.Grant { if err := i.validateGrantParameters(grantee); err != nil { panic(err) } args := []interface{}{grantee} for _, a := range actions { args = append(args, a) } var returns awsiam.Grant _jsii_.Invoke( i, "grant", args, &returns, ) return returns } func (i *jsiiProxy_IDatabaseCluster) GrantConnect(grantee awsiam.IGrantable) awsiam.Grant { if err := i.validateGrantConnectParameters(grantee); err != nil { panic(err) } var returns awsiam.Grant _jsii_.Invoke( i, "grantConnect", []interface{}{grantee}, &returns, ) return returns } func (i *jsiiProxy_IDatabaseCluster) Metric(metricName *string, props *awscloudwatch.MetricOptions) awscloudwatch.Metric { if err := i.validateMetricParameters(metricName, props); err != nil { panic(err) } var returns awscloudwatch.Metric _jsii_.Invoke( i, "metric", []interface{}{metricName, props}, &returns, ) return returns } func (i *jsiiProxy_IDatabaseCluster) ApplyRemovalPolicy(policy awscdk.RemovalPolicy) { if err := i.validateApplyRemovalPolicyParameters(policy); err != nil { panic(err) } _jsii_.InvokeVoid( i, "applyRemovalPolicy", []interface{}{policy}, ) } func (j *jsiiProxy_IDatabaseCluster) ClusterEndpoint() Endpoint { var returns Endpoint _jsii_.Get( j, "clusterEndpoint", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) ClusterIdentifier() *string { var returns *string _jsii_.Get( j, "clusterIdentifier", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) ClusterReadEndpoint() Endpoint { var returns Endpoint _jsii_.Get( j, "clusterReadEndpoint", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) ClusterResourceIdentifier() *string { var returns *string _jsii_.Get( j, "clusterResourceIdentifier", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) Connections() awsec2.Connections { var returns awsec2.Connections _jsii_.Get( j, "connections", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) Env() *awscdk.ResourceEnvironment { var returns *awscdk.ResourceEnvironment _jsii_.Get( j, "env", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) Node() constructs.Node { var returns constructs.Node _jsii_.Get( j, "node", &returns, ) return returns } func (j *jsiiProxy_IDatabaseCluster) Stack() awscdk.Stack { var returns awscdk.Stack _jsii_.Get( j, "stack", &returns, ) return returns }