Class CfnAssociationProps.Builder
- All Implemented Interfaces:
software.amazon.jsii.Builder<CfnAssociationProps>
- Enclosing interface:
CfnAssociationProps
CfnAssociationProps
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionapplyOnlyAtCronInterval
(Boolean applyOnlyAtCronInterval) Sets the value ofCfnAssociationProps.getApplyOnlyAtCronInterval()
applyOnlyAtCronInterval
(IResolvable applyOnlyAtCronInterval) Sets the value ofCfnAssociationProps.getApplyOnlyAtCronInterval()
associationName
(String associationName) Sets the value ofCfnAssociationProps.getAssociationName()
automationTargetParameterName
(String automationTargetParameterName) Sets the value ofCfnAssociationProps.getAutomationTargetParameterName()
build()
Builds the configured instance.calendarNames
(List<String> calendarNames) Sets the value ofCfnAssociationProps.getCalendarNames()
complianceSeverity
(String complianceSeverity) Sets the value ofCfnAssociationProps.getComplianceSeverity()
documentVersion
(String documentVersion) Sets the value ofCfnAssociationProps.getDocumentVersion()
instanceId
(String instanceId) Sets the value ofCfnAssociationProps.getInstanceId()
maxConcurrency
(String maxConcurrency) Sets the value ofCfnAssociationProps.getMaxConcurrency()
Sets the value ofCfnAssociationProps.getMaxErrors()
Sets the value ofCfnAssociationProps.getName()
outputLocation
(IResolvable outputLocation) Sets the value ofCfnAssociationProps.getOutputLocation()
Sets the value ofCfnAssociationProps.getOutputLocation()
parameters
(Object parameters) Sets the value ofCfnAssociationProps.getParameters()
scheduleExpression
(String scheduleExpression) Sets the value ofCfnAssociationProps.getScheduleExpression()
scheduleOffset
(Number scheduleOffset) Sets the value ofCfnAssociationProps.getScheduleOffset()
syncCompliance
(String syncCompliance) Sets the value ofCfnAssociationProps.getSyncCompliance()
Sets the value ofCfnAssociationProps.getTargets()
targets
(IResolvable targets) Sets the value ofCfnAssociationProps.getTargets()
waitForSuccessTimeoutSeconds
(Number waitForSuccessTimeoutSeconds) Sets the value ofCfnAssociationProps.getWaitForSuccessTimeoutSeconds()
-
Constructor Details
-
Builder
public Builder()
-
-
Method Details
-
name
Sets the value ofCfnAssociationProps.getName()
- Parameters:
name
- The name of the SSM document that contains the configuration information for the instance. This parameter is required. You can specifyCommand
orAutomation
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
orMy-Document
.- Returns:
this
-
applyOnlyAtCronInterval
@Stability(Stable) public CfnAssociationProps.Builder applyOnlyAtCronInterval(Boolean applyOnlyAtCronInterval) Sets the value ofCfnAssociationProps.getApplyOnlyAtCronInterval()
- Parameters:
applyOnlyAtCronInterval
- 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. 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.- Returns:
this
-
applyOnlyAtCronInterval
@Stability(Stable) public CfnAssociationProps.Builder applyOnlyAtCronInterval(IResolvable applyOnlyAtCronInterval) Sets the value ofCfnAssociationProps.getApplyOnlyAtCronInterval()
- Parameters:
applyOnlyAtCronInterval
- 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. 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.- Returns:
this
-
associationName
Sets the value ofCfnAssociationProps.getAssociationName()
- Parameters:
associationName
- Specify a descriptive name for the association.- Returns:
this
-
automationTargetParameterName
@Stability(Stable) public CfnAssociationProps.Builder automationTargetParameterName(String automationTargetParameterName) Sets the value ofCfnAssociationProps.getAutomationTargetParameterName()
- Parameters:
automationTargetParameterName
- Choose the parameter that will define how your automation will branch out. 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 .- Returns:
this
-
calendarNames
Sets the value ofCfnAssociationProps.getCalendarNames()
- Parameters:
calendarNames
- The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under. The associations only run when that Change Calendar is open. For more information, see AWS Systems Manager Change Calendar .- Returns:
this
-
complianceSeverity
Sets the value ofCfnAssociationProps.getComplianceSeverity()
- Parameters:
complianceSeverity
- The severity level that is assigned to the association.- Returns:
this
-
documentVersion
Sets the value ofCfnAssociationProps.getDocumentVersion()
- Parameters:
documentVersion
- The version of the SSM document to associate with the target.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
default
version 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
. DocumentVersion
is not valid for documents owned by AWS , such asAWS-RunPatchBaseline
orAWS-UpdateSSMAgent
. If you specifyDocumentVersion
for an AWS document, the system returns the following error: "Error occurred during operation 'CreateAssociation'." (RequestToken:, HandlerErrorCode: GeneralServiceException).
- 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
- Returns:
this
-
instanceId
Sets the value ofCfnAssociationProps.getInstanceId()
- Parameters:
instanceId
- The ID of the instance that the SSM document is associated with. You must specify theInstanceId
orTargets
property.InstanceId
has been deprecated. To specify an instance ID for an association, use theTargets
parameter. If you use the parameterInstanceId
, you cannot use the parametersAssociationName
,DocumentVersion
,MaxErrors
,MaxConcurrency
,OutputLocation
, orScheduleExpression
. To use these parameters, you must use theTargets
parameter.- Returns:
this
-
maxConcurrency
Sets the value ofCfnAssociationProps.getMaxConcurrency()
- Parameters:
maxConcurrency
- The maximum number of targets allowed to run the association at the same time. 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 forMaxConcurrency
.- Returns:
this
-
maxErrors
Sets the value ofCfnAssociationProps.getMaxErrors()
- Parameters:
maxErrors
- The number of errors that are allowed before the system stops sending requests to run the association on additional targets. 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 setMaxError
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, setMaxConcurrency
to 1 so that executions proceed one at a time.- Returns:
this
-
outputLocation
Sets the value ofCfnAssociationProps.getOutputLocation()
- Parameters:
outputLocation
- An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.- Returns:
this
-
outputLocation
@Stability(Stable) public CfnAssociationProps.Builder outputLocation(CfnAssociation.InstanceAssociationOutputLocationProperty outputLocation) Sets the value ofCfnAssociationProps.getOutputLocation()
- Parameters:
outputLocation
- An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.- Returns:
this
-
parameters
Sets the value ofCfnAssociationProps.getParameters()
- Parameters:
parameters
- The parameters for the runtime configuration of the document.- Returns:
this
-
scheduleExpression
Sets the value ofCfnAssociationProps.getScheduleExpression()
- Parameters:
scheduleExpression
- A cron expression that specifies a schedule when the association runs. The schedule runs in Coordinated Universal Time (UTC).- Returns:
this
-
scheduleOffset
Sets the value ofCfnAssociationProps.getScheduleOffset()
- Parameters:
scheduleOffset
- Number of days to wait after the scheduled day to run an association.- Returns:
this
-
syncCompliance
Sets the value ofCfnAssociationProps.getSyncCompliance()
- Parameters:
syncCompliance
- The mode for generating association compliance. You can specifyAUTO
orMANUAL
. InAUTO
mode, the system uses the status of the association execution to determine the compliance status. If the association execution runs successfully, then the association isCOMPLIANT
. If the association execution doesn't run successfully, the association isNON-COMPLIANT
.In
MANUAL
mode, you must specify theAssociationId
as a parameter for thePutComplianceItems
API action. In this case, compliance data is not managed by State Manager. It is managed by your direct call to thePutComplianceItems
API action.By default, all associations use
AUTO
mode.- Returns:
this
-
targets
Sets the value ofCfnAssociationProps.getTargets()
- Parameters:
targets
- The targets for the association. You must specify theInstanceId
orTargets
property. You can target all instances in an AWS account by specifying t heInstanceIds
key with a value of*
.Supported formats include the following.
Key=InstanceIds,Values=<instance-id-1>,<instance-id-2>,<instance-id-3>
Key=tag-key,Values=<my-tag-key-1>,<my-tag-key-2>
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.
- Returns:
this
-
targets
Sets the value ofCfnAssociationProps.getTargets()
- Parameters:
targets
- The targets for the association. You must specify theInstanceId
orTargets
property. You can target all instances in an AWS account by specifying t heInstanceIds
key with a value of*
.Supported formats include the following.
Key=InstanceIds,Values=<instance-id-1>,<instance-id-2>,<instance-id-3>
Key=tag-key,Values=<my-tag-key-1>,<my-tag-key-2>
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.
- Returns:
this
-
waitForSuccessTimeoutSeconds
@Stability(Stable) public CfnAssociationProps.Builder waitForSuccessTimeoutSeconds(Number waitForSuccessTimeoutSeconds) Sets the value ofCfnAssociationProps.getWaitForSuccessTimeoutSeconds()
- Parameters:
waitForSuccessTimeoutSeconds
- The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution. If the association status doesn't show "Success" after the specified number of seconds, then stack creation fails.When you specify a value for the
WaitForSuccessTimeoutSeconds
, drift detection for your AWS CloudFormation stack’s configuration might yield inaccurate results. If drift detection is important in your scenario, we recommend that you don’t includeWaitForSuccessTimeoutSeconds
in your template.- Returns:
this
-
build
Builds the configured instance.- Specified by:
build
in interfacesoftware.amazon.jsii.Builder<CfnAssociationProps>
- Returns:
- a new instance of
CfnAssociationProps
- Throws:
NullPointerException
- if any required attribute was not provided
-