Skip to content

RosInstance

This class is a base encapsulation around the ROS resource type ALIYUN::DMS::Instance, which is used to register a database instance for your enterprise.

Initializers

import { RosInstance } from '@alicloud/ros-cdk-dms'
new RosInstance(scope: Construct, id: string, props: RosInstanceProps, enableResourcePropertyConstraint: boolean)
Name Type Description
scope @alicloud/ros-cdk-core.Construct - scope in which this resource is defined.
id string - scoped id of the resource.
props RosInstanceProps - resource properties.
enableResourcePropertyConstraint boolean No description.

scopeRequired

  • Type: @alicloud/ros-cdk-core.Construct

scope in which this resource is defined.


idRequired

  • Type: string

scoped id of the resource.


propsRequired

resource properties.


enableResourcePropertyConstraintRequired

  • Type: boolean

Methods

Name Description
toString Returns a string representation of this construct.
synthesize Allows this construct to emit artifacts into the cloud assembly during synthesis.
overrideLogicalId Overrides the auto-generated logical ID with a specific ID.
addCondition No description.
addCount No description.
addDeletionOverride Syntactic sugar for addOverride(path, undefined).
addDependsOn Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
addDesc No description.
addMetaData No description.
addOverride Adds an override to the synthesized ROS resource.
addPropertyDeletionOverride Adds an override that deletes the value of a property from the resource definition.
addPropertyOverride Adds an override to a resource property.
addRosDependency No description.
applyRemovalPolicy Sets the deletion policy of the resource based on the removal policy specified.
getAtt Returns a token for an runtime attribute of this resource.

toString

public toString(): string

Returns a string representation of this construct.

synthesize

public synthesize(session: ISynthesisSession): void

Allows this construct to emit artifacts into the cloud assembly during synthesis.

This method is usually implemented by framework-level constructs such as Stack and Asset as they participate in synthesizing the cloud assembly.

sessionRequired

  • Type: @alicloud/ros-cdk-core.ISynthesisSession

The synthesis session.


overrideLogicalId

public overrideLogicalId(newLogicalId: string): void

Overrides the auto-generated logical ID with a specific ID.

newLogicalIdRequired

  • Type: string

The new logical ID to use for this stack element.


addCondition

public addCondition(con: RosCondition): void

conRequired

  • Type: @alicloud/ros-cdk-core.RosCondition

addCount

public addCount(count: number | IResolvable): void

countRequired

  • Type: number | @alicloud/ros-cdk-core.IResolvable

addDeletionOverride

public addDeletionOverride(path: string): void

Syntactic sugar for addOverride(path, undefined).

pathRequired

  • Type: string

The path of the value to delete.


addDependsOn

public addDependsOn(target: RosResource): void

Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.

This can be used for resources across stacks (or nested stack) boundaries and the dependency will automatically be transferred to the relevant scope.

targetRequired

  • Type: @alicloud/ros-cdk-core.RosResource

addDesc

public addDesc(desc: string): void

descRequired

  • Type: string

addMetaData

public addMetaData(key: string, value: any): void

keyRequired

  • Type: string

valueRequired

  • Type: any

addOverride

public addOverride(path: string, value: any): void

Adds an override to the synthesized ROS resource.

To add a property override, either use addPropertyOverride or prefix path with "Properties." (i.e. Properties.TopicName).

If the override is nested, separate each nested level using a dot (.) in the path parameter. If there is an array as part of the nesting, specify the index in the path.

For example,

addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute'])
addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE')

would add the overrides

"Properties": {
   "GlobalSecondaryIndexes": [
     {
       "Projection": {
         "NonKeyAttributes": [ "myattribute" ]
         ...
       }
       ...
     },
     {
       "ProjectionType": "INCLUDE"
       ...
     },
   ]
   ...
}

pathRequired

  • Type: string

The path of the property, you can use dot notation to override values in complex types.

Any intermdediate keys will be created as needed.


valueRequired

  • Type: any

The value.

Could be primitive or complex.


addPropertyDeletionOverride

public addPropertyDeletionOverride(propertyPath: string): void

Adds an override that deletes the value of a property from the resource definition.

propertyPathRequired

  • Type: string

The path to the property.


addPropertyOverride

public addPropertyOverride(propertyPath: string, value: any): void

Adds an override to a resource property.

Syntactic sugar for addOverride("Properties.<...>", value).

propertyPathRequired

  • Type: string

The path of the property.


valueRequired

  • Type: any

The value.


addRosDependency

public addRosDependency(target: string): void

targetRequired

  • Type: string

applyRemovalPolicy

public applyRemovalPolicy(policy?: RemovalPolicy, options?: RemovalPolicyOptions): void

Sets the deletion policy of the resource based on the removal policy specified.

policyOptional

  • Type: @alicloud/ros-cdk-core.RemovalPolicy

optionsOptional

  • Type: @alicloud/ros-cdk-core.RemovalPolicyOptions

getAtt

public getAtt(attributeName: string): Reference

Returns a token for an runtime attribute of this resource.

Ideally, use generated attribute accessors (e.g. resource.arn), but this can be used for future compatibility in case there is no generated attribute.

attributeNameRequired

  • Type: string

The name of the attribute.


Static Functions

Name Description
isConstruct Return whether the given object is a Construct.
isRosElement Returns true if a construct is a stack element (i.e. part of the synthesized template).
isRosResource Check whether the given construct is a RosResource.

isConstruct

import { RosInstance } from '@alicloud/ros-cdk-dms'
RosInstance.isConstruct(x: any)

Return whether the given object is a Construct.

xRequired

  • Type: any

isRosElement

import { RosInstance } from '@alicloud/ros-cdk-dms'
RosInstance.isRosElement(x: any)

Returns true if a construct is a stack element (i.e. part of the synthesized template).

Uses duck-typing instead of instanceof to allow stack elements from different versions of this library to be included in the same stack.

xRequired

  • Type: any

isRosResource

import { RosInstance } from '@alicloud/ros-cdk-dms'
RosInstance.isRosResource(construct: IConstruct)

Check whether the given construct is a RosResource.

constructRequired

  • Type: @alicloud/ros-cdk-core.IConstruct

Properties

Name Type Description
node @alicloud/ros-cdk-core.ConstructNode The construct tree node associated with this construct.
creationStack string[] No description.
logicalId string The logical ID for this stack element.
stack @alicloud/ros-cdk-core.Stack The stack in which this element is defined.
ref string Return a string that will be resolved to a RosTemplate { Ref } for this element.
rosOptions @alicloud/ros-cdk-core.IRosResourceOptions Options for this resource, such as condition, update policy etc.
rosResourceType string ROS resource type.
attrHost @alicloud/ros-cdk-core.IResolvable No description.
attrInstanceId @alicloud/ros-cdk-core.IResolvable No description.
attrPort @alicloud/ros-cdk-core.IResolvable No description.
databasePassword string | @alicloud/ros-cdk-core.IResolvable No description.
databaseUser string | @alicloud/ros-cdk-core.IResolvable No description.
dbaUid number | @alicloud/ros-cdk-core.IResolvable No description.
enableResourcePropertyConstraint boolean No description.
envType string | @alicloud/ros-cdk-core.IResolvable No description.
exportTimeout number | @alicloud/ros-cdk-core.IResolvable No description.
host string | @alicloud/ros-cdk-core.IResolvable No description.
instanceAlias string | @alicloud/ros-cdk-core.IResolvable No description.
instanceSource string | @alicloud/ros-cdk-core.IResolvable No description.
instanceType string | @alicloud/ros-cdk-core.IResolvable No description.
networkType string | @alicloud/ros-cdk-core.IResolvable No description.
port number | @alicloud/ros-cdk-core.IResolvable No description.
queryTimeout number | @alicloud/ros-cdk-core.IResolvable No description.
safeRule string | @alicloud/ros-cdk-core.IResolvable No description.
dataLinkName string | @alicloud/ros-cdk-core.IResolvable No description.
ddlOnline number | @alicloud/ros-cdk-core.IResolvable No description.
ecsInstanceId string | @alicloud/ros-cdk-core.IResolvable No description.
ecsRegion string | @alicloud/ros-cdk-core.IResolvable No description.
sid string | @alicloud/ros-cdk-core.IResolvable No description.
tid number | @alicloud/ros-cdk-core.IResolvable No description.
useDsql number | @alicloud/ros-cdk-core.IResolvable No description.
vpcId string | @alicloud/ros-cdk-core.IResolvable No description.

nodeRequired

public readonly node: ConstructNode;
  • Type: @alicloud/ros-cdk-core.ConstructNode

The construct tree node associated with this construct.


creationStackRequired

public readonly creationStack: string[];
  • Type: string[]

logicalIdRequired

public readonly logicalId: string;
  • Type: string

The logical ID for this stack element.

The logical ID of the element is calculated from the path of the resource node in the construct tree.

To override this value, use overrideLogicalId(newLogicalId).


stackRequired

public readonly stack: Stack;
  • Type: @alicloud/ros-cdk-core.Stack

The stack in which this element is defined.

RosElements must be defined within a stack scope (directly or indirectly).


refRequired

public readonly ref: string;
  • Type: string

Return a string that will be resolved to a RosTemplate { Ref } for this element.

If, by any chance, the intrinsic reference of a resource is not a string, you could coerce it to an IResolvable through Lazy.any({ produce: resource.ref }).


rosOptionsRequired

public readonly rosOptions: IRosResourceOptions;
  • Type: @alicloud/ros-cdk-core.IRosResourceOptions

Options for this resource, such as condition, update policy etc.


rosResourceTypeRequired

public readonly rosResourceType: string;
  • Type: string

ROS resource type.


attrHostRequired

public readonly attrHost: IResolvable;
  • Type: @alicloud/ros-cdk-core.IResolvable

attrInstanceIdRequired

public readonly attrInstanceId: IResolvable;
  • Type: @alicloud/ros-cdk-core.IResolvable

attrPortRequired

public readonly attrPort: IResolvable;
  • Type: @alicloud/ros-cdk-core.IResolvable

databasePasswordRequired

public readonly databasePassword: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

databaseUserRequired

public readonly databaseUser: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

dbaUidRequired

public readonly dbaUid: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

enableResourcePropertyConstraintRequired

public readonly enableResourcePropertyConstraint: boolean;
  • Type: boolean

envTypeRequired

public readonly envType: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

exportTimeoutRequired

public readonly exportTimeout: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

hostRequired

public readonly host: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

instanceAliasRequired

public readonly instanceAlias: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

instanceSourceRequired

public readonly instanceSource: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

instanceTypeRequired

public readonly instanceType: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

networkTypeRequired

public readonly networkType: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

portRequired

public readonly port: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

queryTimeoutRequired

public readonly queryTimeout: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

safeRuleRequired

public readonly safeRule: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

dataLinkNameOptional

public readonly dataLinkName: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

ddlOnlineOptional

public readonly ddlOnline: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

ecsInstanceIdOptional

public readonly ecsInstanceId: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

ecsRegionOptional

public readonly ecsRegion: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

sidOptional

public readonly sid: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

tidOptional

public readonly tid: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

useDsqlOptional

public readonly useDsql: number | IResolvable;
  • Type: number | @alicloud/ros-cdk-core.IResolvable

vpcIdOptional

public readonly vpcId: string | IResolvable;
  • Type: string | @alicloud/ros-cdk-core.IResolvable

Constants

Name Type Description
ROS_RESOURCE_TYPE_NAME string The resource type name for this resource class.

ROS_RESOURCE_TYPE_NAMERequired

public readonly ROS_RESOURCE_TYPE_NAME: string;
  • Type: string

The resource type name for this resource class.