@Generated(value="jsii-pacmak/1.67.0 (build 2c027f5)", date="2022-09-19T20:26:42.290Z") @Stability(value=Stable) public class CfnAssociation extends CfnResource implements IInspectable
The AWS::SSM::Association resource creates a State Manager association for your managed instances. A State Manager association defines the state that you want to maintain on your instances. For example, an association can specify that anti-virus software must be installed and running on your instances, or that certain ports must be closed. For static targets, the association specifies a schedule for when the configuration is reapplied. For dynamic targets, such as an AWS Resource Groups or an AWS Auto Scaling Group, State Manager applies the configuration when new instances are added to the group. The association also specifies actions to take when applying the configuration. For example, an association for anti-virus software might run once a day. If the software is not installed, then State Manager installs it. If the software is installed, but the service is not running, then the association might instruct State Manager to start the service.
Example:
// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import software.amazon.awscdk.services.ssm.*;
Object parameters;
CfnAssociation cfnAssociation = CfnAssociation.Builder.create(this, "MyCfnAssociation")
.name("name")
// the properties below are optional
.applyOnlyAtCronInterval(false)
.associationName("associationName")
.automationTargetParameterName("automationTargetParameterName")
.calendarNames(List.of("calendarNames"))
.complianceSeverity("complianceSeverity")
.documentVersion("documentVersion")
.instanceId("instanceId")
.maxConcurrency("maxConcurrency")
.maxErrors("maxErrors")
.outputLocation(InstanceAssociationOutputLocationProperty.builder()
.s3Location(S3OutputLocationProperty.builder()
.outputS3BucketName("outputS3BucketName")
.outputS3KeyPrefix("outputS3KeyPrefix")
.outputS3Region("outputS3Region")
.build())
.build())
.parameters(Map.of(
"parametersKey", parameters))
.scheduleExpression("scheduleExpression")
.scheduleOffset(123)
.syncCompliance("syncCompliance")
.targets(List.of(TargetProperty.builder()
.key("key")
.values(List.of("values"))
.build()))
.waitForSuccessTimeoutSeconds(123)
.build();
| Modifier and Type | Class and Description |
|---|---|
static class |
CfnAssociation.Builder
A fluent builder for
CfnAssociation. |
static interface |
CfnAssociation.InstanceAssociationOutputLocationProperty
`InstanceAssociationOutputLocation` is a property of the [AWS::SSM::Association](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ssm-association.html) resource that specifies an Amazon S3 bucket where you want to store the results of this association request.
|
static interface |
CfnAssociation.S3OutputLocationProperty
`S3OutputLocation` is a property of the [AWS::SSM::Association](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ssm-association.html) resource that specifies an Amazon S3 bucket where you want to store the results of this association request.
|
static interface |
CfnAssociation.TargetProperty
`Target` is a property of the [AWS::SSM::Association](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ssm-association.html) resource that specifies the targets for an SSM document in Systems Manager .
|
software.amazon.jsii.JsiiObject.InitializationModeIInspectable.Jsii$Default, IInspectable.Jsii$Proxy| Modifier and Type | Field and Description |
|---|---|
static String |
CFN_RESOURCE_TYPE_NAME
The CloudFormation resource type name for this resource class.
|
| Modifier | Constructor and Description |
|---|---|
|
CfnAssociation(software.constructs.Construct scope,
String id,
CfnAssociationProps props)
Create a new `AWS::SSM::Association`.
|
protected |
CfnAssociation(software.amazon.jsii.JsiiObject.InitializationMode initializationMode) |
protected |
CfnAssociation(software.amazon.jsii.JsiiObjectRef objRef) |
| Modifier and Type | Method and Description |
|---|---|
Object |
getApplyOnlyAtCronInterval()
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.
|
String |
getAssociationName()
Specify a descriptive name for the association.
|
String |
getAttrAssociationId()
The association ID.
|
String |
getAutomationTargetParameterName()
Choose the parameter that will define how your automation will branch out.
|
List<String> |
getCalendarNames()
The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.
|
protected Map<String,Object> |
getCfnProperties() |
String |
getComplianceSeverity()
The severity level that is assigned to the association.
|
String |
getDocumentVersion()
The version of the SSM document to associate with the target.
|
String |
getInstanceId()
The ID of the instance that the SSM document is associated with.
|
String |
getMaxConcurrency()
The maximum number of targets allowed to run the association at the same time.
|
String |
getMaxErrors()
The number of errors that are allowed before the system stops sending requests to run the association on additional targets.
|
String |
getName()
The name of the SSM document that contains the configuration information for the instance.
|
Object |
getOutputLocation()
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.
|
Object |
getParameters()
The parameters for the runtime configuration of the document.
|
String |
getScheduleExpression()
A cron expression that specifies a schedule when the association runs.
|
Number |
getScheduleOffset()
Number of days to wait after the scheduled day to run an association.
|
String |
getSyncCompliance()
The mode for generating association compliance.
|
Object |
getTargets()
The targets for the association.
|
Number |
getWaitForSuccessTimeoutSeconds()
The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.
|
void |
inspect(TreeInspector inspector)
Examines the CloudFormation resource and discloses attributes.
|
protected Map<String,Object> |
renderProperties(Map<String,Object> props) |
void |
setApplyOnlyAtCronInterval(Boolean value)
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.
|
void |
setApplyOnlyAtCronInterval(IResolvable value)
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.
|
void |
setAssociationName(String value)
Specify a descriptive name for the association.
|
void |
setAutomationTargetParameterName(String value)
Choose the parameter that will define how your automation will branch out.
|
void |
setCalendarNames(List<String> value)
The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.
|
void |
setComplianceSeverity(String value)
The severity level that is assigned to the association.
|
void |
setDocumentVersion(String value)
The version of the SSM document to associate with the target.
|
void |
setInstanceId(String value)
The ID of the instance that the SSM document is associated with.
|
void |
setMaxConcurrency(String value)
The maximum number of targets allowed to run the association at the same time.
|
void |
setMaxErrors(String value)
The number of errors that are allowed before the system stops sending requests to run the association on additional targets.
|
void |
setName(String value)
The name of the SSM document that contains the configuration information for the instance.
|
void |
setOutputLocation(CfnAssociation.InstanceAssociationOutputLocationProperty value)
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.
|
void |
setOutputLocation(IResolvable value)
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.
|
void |
setParameters(IResolvable value)
The parameters for the runtime configuration of the document.
|
void |
setParameters(Map<String,Object> value)
The parameters for the runtime configuration of the document.
|
void |
setScheduleExpression(String value)
A cron expression that specifies a schedule when the association runs.
|
void |
setScheduleOffset(Number value)
Number of days to wait after the scheduled day to run an association.
|
void |
setSyncCompliance(String value)
The mode for generating association compliance.
|
void |
setTargets(IResolvable value)
The targets for the association.
|
void |
setTargets(List<Object> value)
The targets for the association.
|
void |
setWaitForSuccessTimeoutSeconds(Number value)
The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.
|
addDeletionOverride, addDependsOn, addMetadata, addOverride, addPropertyDeletionOverride, addPropertyOverride, applyRemovalPolicy, applyRemovalPolicy, applyRemovalPolicy, getAtt, getCfnOptions, getCfnResourceType, getMetadata, getUpdatedProperites, getUpdatedProperties, isCfnResource, shouldSynthesize, toString, validatePropertiesgetRefgetCreationStack, getLogicalId, getStack, isCfnElement, overrideLogicalIdjsiiAsyncCall, jsiiAsyncCall, jsiiCall, jsiiCall, jsiiGet, jsiiGet, jsiiSet, jsiiStaticCall, jsiiStaticCall, jsiiStaticGet, jsiiStaticGet, jsiiStaticSet, jsiiStaticSet@Stability(value=Stable) public static final String CFN_RESOURCE_TYPE_NAME
protected CfnAssociation(software.amazon.jsii.JsiiObjectRef objRef)
protected CfnAssociation(software.amazon.jsii.JsiiObject.InitializationMode initializationMode)
@Stability(value=Stable)
public CfnAssociation(@NotNull
software.constructs.Construct scope,
@NotNull
String id,
@NotNull
CfnAssociationProps props)
scope - - scope in which this resource is defined. This parameter is required.id - - scoped id of the resource. This parameter is required.props - - resource properties. This parameter is required.@Stability(value=Stable)
public void inspect(@NotNull
TreeInspector inspector)
inspect in interface IInspectableinspector - - tree inspector to collect and process attributes. This parameter is required.@Stability(value=Stable) @NotNull protected Map<String,Object> renderProperties(@NotNull Map<String,Object> props)
renderProperties in class CfnResourceprops - This parameter is required.@Stability(value=Stable) @NotNull public String getAttrAssociationId()
@Stability(value=Stable) @NotNull protected Map<String,Object> getCfnProperties()
getCfnProperties in class CfnResource@Stability(value=Stable) @NotNull public String getName()
You can specify Command or Automation documents. The documents can be AWS -predefined documents, documents you created, or a document that is shared with you from another account. For SSM documents that are shared with you from other AWS accounts , you must specify the complete SSM document ARN, in the following format:
arn:partition:ssm:region:account-id:document/document-name
For example: arn:aws:ssm:us-east-2:12345678912:document/My-Shared-Document
For AWS -predefined documents and SSM documents you created in your account, you only need to specify the document name. For example, AWS -ApplyPatchBaseline or My-Document.
@Stability(value=Stable)
public void setName(@NotNull
String value)
You can specify Command or Automation documents. The documents can be AWS -predefined documents, documents you created, or a document that is shared with you from another account. For SSM documents that are shared with you from other AWS accounts , you must specify the complete SSM document ARN, in the following format:
arn:partition:ssm:region:account-id:document/document-name
For example: arn:aws:ssm:us-east-2:12345678912:document/My-Shared-Document
For AWS -predefined documents and SSM documents you created in your account, you only need to specify the document name. For example, AWS -ApplyPatchBaseline or My-Document.
@Stability(value=Stable) @Nullable public Object getApplyOnlyAtCronInterval()
Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
@Stability(value=Stable)
public void setApplyOnlyAtCronInterval(@Nullable
Boolean value)
Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
@Stability(value=Stable)
public void setApplyOnlyAtCronInterval(@Nullable
IResolvable value)
Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
@Stability(value=Stable) @Nullable public String getAssociationName()
@Stability(value=Stable)
public void setAssociationName(@Nullable
String value)
@Stability(value=Stable) @Nullable public String getAutomationTargetParameterName()
This target is required for associations that use an Automation runbook and target resources by using rate controls. Automation is a capability of AWS Systems Manager .
@Stability(value=Stable)
public void setAutomationTargetParameterName(@Nullable
String value)
This target is required for associations that use an Automation runbook and target resources by using rate controls. Automation is a capability of AWS Systems Manager .
@Stability(value=Stable) @Nullable public List<String> getCalendarNames()
The associations only run when that Change Calendar is open. For more information, see AWS Systems Manager Change Calendar .
@Stability(value=Stable)
public void setCalendarNames(@Nullable
List<String> value)
The associations only run when that Change Calendar is open. For more information, see AWS Systems Manager Change Calendar .
@Stability(value=Stable) @Nullable public String getComplianceSeverity()
@Stability(value=Stable)
public void setComplianceSeverity(@Nullable
String value)
@Stability(value=Stable) @Nullable public String getDocumentVersion()
Note the following important information.
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
defaultversion of a document if shared from another account, even though the Systems Manager console shows that a new version was processed. If you want to run an association using a new version of a document shared form another account, you must set the document version todefault.DocumentVersionis not valid for documents owned by AWS , such asAWS-RunPatchBaselineorAWS-UpdateSSMAgent. If you specifyDocumentVersionfor an AWS document, the system returns the following error: "Error occurred during operation 'CreateAssociation'." (RequestToken:, HandlerErrorCode: GeneralServiceException).
@Stability(value=Stable)
public void setDocumentVersion(@Nullable
String value)
Note the following important information.
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
defaultversion of a document if shared from another account, even though the Systems Manager console shows that a new version was processed. If you want to run an association using a new version of a document shared form another account, you must set the document version todefault.DocumentVersionis not valid for documents owned by AWS , such asAWS-RunPatchBaselineorAWS-UpdateSSMAgent. If you specifyDocumentVersionfor an AWS document, the system returns the following error: "Error occurred during operation 'CreateAssociation'." (RequestToken:, HandlerErrorCode: GeneralServiceException).
@Stability(value=Stable) @Nullable public String getInstanceId()
You must specify the InstanceId or Targets property.
InstanceIdhas been deprecated. To specify an instance ID for an association, use theTargetsparameter. If you use the parameterInstanceId, you cannot use the parametersAssociationName,DocumentVersion,MaxErrors,MaxConcurrency,OutputLocation, orScheduleExpression. To use these parameters, you must use theTargetsparameter.
@Stability(value=Stable)
public void setInstanceId(@Nullable
String value)
You must specify the InstanceId or Targets property.
InstanceIdhas been deprecated. To specify an instance ID for an association, use theTargetsparameter. If you use the parameterInstanceId, you cannot use the parametersAssociationName,DocumentVersion,MaxErrors,MaxConcurrency,OutputLocation, orScheduleExpression. To use these parameters, you must use theTargetsparameter.
@Stability(value=Stable) @Nullable public String getMaxConcurrency()
You can specify a number, for example 10, or a percentage of the target set, for example 10%. The default value is 100%, which means all targets run the association at the same time.
If a new managed node starts and attempts to run an association while Systems Manager is running MaxConcurrency associations, the association is allowed to run. During the next association interval, the new managed node will process its association within the limit specified for MaxConcurrency .
@Stability(value=Stable)
public void setMaxConcurrency(@Nullable
String value)
You can specify a number, for example 10, or a percentage of the target set, for example 10%. The default value is 100%, which means all targets run the association at the same time.
If a new managed node starts and attempts to run an association while Systems Manager is running MaxConcurrency associations, the association is allowed to run. During the next association interval, the new managed node will process its association within the limit specified for MaxConcurrency .
@Stability(value=Stable) @Nullable public String getMaxErrors()
You can specify either an absolute number of errors, for example 10, or a percentage of the target set, for example 10%. If you specify 3, for example, the system stops sending requests when the fourth error is received. If you specify 0, then the system stops sending requests after the first error is returned. If you run an association on 50 managed nodes and set MaxError to 10%, then the system stops sending the request when the sixth error is received.
Executions that are already running an association when MaxErrors is reached are allowed to complete, but some of these executions may fail as well. If you need to ensure that there won't be more than max-errors failed executions, set MaxConcurrency to 1 so that executions proceed one at a time.
@Stability(value=Stable)
public void setMaxErrors(@Nullable
String value)
You can specify either an absolute number of errors, for example 10, or a percentage of the target set, for example 10%. If you specify 3, for example, the system stops sending requests when the fourth error is received. If you specify 0, then the system stops sending requests after the first error is returned. If you run an association on 50 managed nodes and set MaxError to 10%, then the system stops sending the request when the sixth error is received.
Executions that are already running an association when MaxErrors is reached are allowed to complete, but some of these executions may fail as well. If you need to ensure that there won't be more than max-errors failed executions, set MaxConcurrency to 1 so that executions proceed one at a time.
@Stability(value=Stable) @Nullable public Object getOutputLocation()
@Stability(value=Stable)
public void setOutputLocation(@Nullable
CfnAssociation.InstanceAssociationOutputLocationProperty value)
@Stability(value=Stable)
public void setOutputLocation(@Nullable
IResolvable value)
@Stability(value=Stable) @Nullable public Object getParameters()
@Stability(value=Stable)
public void setParameters(@Nullable
IResolvable value)
@Stability(value=Stable)
public void setParameters(@Nullable
Map<String,Object> value)
@Stability(value=Stable) @Nullable public String getScheduleExpression()
The schedule runs in Coordinated Universal Time (UTC).
@Stability(value=Stable)
public void setScheduleExpression(@Nullable
String value)
The schedule runs in Coordinated Universal Time (UTC).
@Stability(value=Stable) @Nullable public Number getScheduleOffset()
@Stability(value=Stable)
public void setScheduleOffset(@Nullable
Number value)
@Stability(value=Stable) @Nullable public String getSyncCompliance()
You can specify AUTO or MANUAL . In AUTO mode, the system uses the status of the association execution to determine the compliance status. If the association execution runs successfully, then the association is COMPLIANT . If the association execution doesn't run successfully, the association is NON-COMPLIANT .
In MANUAL mode, you must specify the AssociationId as a parameter for the PutComplianceItems API action. In this case, compliance data is not managed by State Manager. It is managed by your direct call to the PutComplianceItems API action.
By default, all associations use AUTO mode.
@Stability(value=Stable)
public void setSyncCompliance(@Nullable
String value)
You can specify AUTO or MANUAL . In AUTO mode, the system uses the status of the association execution to determine the compliance status. If the association execution runs successfully, then the association is COMPLIANT . If the association execution doesn't run successfully, the association is NON-COMPLIANT .
In MANUAL mode, you must specify the AssociationId as a parameter for the PutComplianceItems API action. In this case, compliance data is not managed by State Manager. It is managed by your direct call to the PutComplianceItems API action.
By default, all associations use AUTO mode.
@Stability(value=Stable) @Nullable public Object getTargets()
You must specify the InstanceId or Targets property. You can target all instances in an AWS account by specifying the InstanceIds key with a value of * . To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page.
@Stability(value=Stable)
public void setTargets(@Nullable
IResolvable value)
You must specify the InstanceId or Targets property. You can target all instances in an AWS account by specifying the InstanceIds key with a value of * . To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page.
@Stability(value=Stable)
public void setTargets(@Nullable
List<Object> value)
You must specify the InstanceId or Targets property. You can target all instances in an AWS account by specifying the InstanceIds key with a value of * . To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page.
@Stability(value=Stable) @Nullable public Number getWaitForSuccessTimeoutSeconds()
If the association status doesn't show "Success" after the specified number of seconds, then stack creation fails.
@Stability(value=Stable)
public void setWaitForSuccessTimeoutSeconds(@Nullable
Number value)
If the association status doesn't show "Success" after the specified number of seconds, then stack creation fails.
Copyright © 2022. All rights reserved.