com.amazonaws.services.arczonalshift.model.ZonalShiftInResource Maven / Gradle / Ivy
Show all versions of aws-java-sdk-arczonalshift Show documentation
/*
* Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package com.amazonaws.services.arczonalshift.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* A complex structure that lists the zonal shifts for a managed resource and their statuses for the resource.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ZonalShiftInResource implements Serializable, Cloneable, StructuredPojo {
/**
*
* The appliedStatus
field specifies which application traffic shift is in effect for a resource when
* there is more than one active traffic shift. There can be more than one application traffic shift in progress at
* the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an autoshift. The
* appliedStatus
field for a shift that is in progress for a resource can have one of two values:
* APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is currently in effect for
* the resource has an appliedStatus
set to APPLIED
.
*
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts > autoshifts
* > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*/
private String appliedStatus;
/**
*
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource when
* you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is instead
* moved to other Availability Zones in the Amazon Web Services Region.
*
*/
private String awayFrom;
/**
*
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no comment
* history is maintained. That is, a new comment overwrites any existing comment string.
*
*/
private String comment;
/**
*
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and must be
* set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a maximum of three
* days (72 hours). However, you can update a zonal shift to set a new expiration at any time.
*
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts to an
* expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to the
* Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another length of
* time to expire in.
*
*/
private java.util.Date expiryTime;
/**
*
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does not go
* into an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal shift
* duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into an
* ALARM
state during the practice run, and the practice run was not interrupted before it completed.
*
*
*
*
* For more information about practice run outcomes, see Considerations when
* you configure zonal autoshift in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*/
private String practiceRunOutcome;
/**
*
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name (ARN) for
* the resource.
*
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers with
* cross-zone load balancing turned off.
*
*/
private String resourceIdentifier;
/**
*
* The time (UTC) when the zonal shift starts.
*
*/
private java.util.Date startTime;
/**
*
* The identifier of a zonal shift.
*
*/
private String zonalShiftId;
/**
*
* The appliedStatus
field specifies which application traffic shift is in effect for a resource when
* there is more than one active traffic shift. There can be more than one application traffic shift in progress at
* the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an autoshift. The
* appliedStatus
field for a shift that is in progress for a resource can have one of two values:
* APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is currently in effect for
* the resource has an appliedStatus
set to APPLIED
.
*
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts > autoshifts
* > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param appliedStatus
* The appliedStatus
field specifies which application traffic shift is in effect for a resource
* when there is more than one active traffic shift. There can be more than one application traffic shift in
* progress at the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an
* autoshift. The appliedStatus
field for a shift that is in progress for a resource can have
* one of two values: APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is
* currently in effect for the resource has an appliedStatus
set to APPLIED
.
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts >
* autoshifts > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer
* Guide.
* @see AppliedStatus
*/
public void setAppliedStatus(String appliedStatus) {
this.appliedStatus = appliedStatus;
}
/**
*
* The appliedStatus
field specifies which application traffic shift is in effect for a resource when
* there is more than one active traffic shift. There can be more than one application traffic shift in progress at
* the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an autoshift. The
* appliedStatus
field for a shift that is in progress for a resource can have one of two values:
* APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is currently in effect for
* the resource has an appliedStatus
set to APPLIED
.
*
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts > autoshifts
* > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @return The appliedStatus
field specifies which application traffic shift is in effect for a
* resource when there is more than one active traffic shift. There can be more than one application traffic
* shift in progress at the same time - that is, practice run zonal shifts, customer-initiated zonal shifts,
* or an autoshift. The appliedStatus
field for a shift that is in progress for a resource can
* have one of two values: APPLIED
or NOT_APPLIED
. The zonal shift or autoshift
* that is currently in effect for the resource has an appliedStatus
set to
* APPLIED
.
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts >
* autoshifts > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer
* Guide.
* @see AppliedStatus
*/
public String getAppliedStatus() {
return this.appliedStatus;
}
/**
*
* The appliedStatus
field specifies which application traffic shift is in effect for a resource when
* there is more than one active traffic shift. There can be more than one application traffic shift in progress at
* the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an autoshift. The
* appliedStatus
field for a shift that is in progress for a resource can have one of two values:
* APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is currently in effect for
* the resource has an appliedStatus
set to APPLIED
.
*
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts > autoshifts
* > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param appliedStatus
* The appliedStatus
field specifies which application traffic shift is in effect for a resource
* when there is more than one active traffic shift. There can be more than one application traffic shift in
* progress at the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an
* autoshift. The appliedStatus
field for a shift that is in progress for a resource can have
* one of two values: APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is
* currently in effect for the resource has an appliedStatus
set to APPLIED
.
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts >
* autoshifts > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer
* Guide.
* @return Returns a reference to this object so that method calls can be chained together.
* @see AppliedStatus
*/
public ZonalShiftInResource withAppliedStatus(String appliedStatus) {
setAppliedStatus(appliedStatus);
return this;
}
/**
*
* The appliedStatus
field specifies which application traffic shift is in effect for a resource when
* there is more than one active traffic shift. There can be more than one application traffic shift in progress at
* the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an autoshift. The
* appliedStatus
field for a shift that is in progress for a resource can have one of two values:
* APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is currently in effect for
* the resource has an appliedStatus
set to APPLIED
.
*
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts > autoshifts
* > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param appliedStatus
* The appliedStatus
field specifies which application traffic shift is in effect for a resource
* when there is more than one active traffic shift. There can be more than one application traffic shift in
* progress at the same time - that is, practice run zonal shifts, customer-initiated zonal shifts, or an
* autoshift. The appliedStatus
field for a shift that is in progress for a resource can have
* one of two values: APPLIED
or NOT_APPLIED
. The zonal shift or autoshift that is
* currently in effect for the resource has an appliedStatus
set to APPLIED
.
*
* The overall principle for precedence is that zonal shifts that you start as a customer take precedence
* autoshifts, which take precedence over practice runs. That is, customer-initiated zonal shifts >
* autoshifts > practice run zonal shifts.
*
*
* For more information, see How zonal
* autoshift and practice runs work in the Amazon Route 53 Application Recovery Controller Developer
* Guide.
* @return Returns a reference to this object so that method calls can be chained together.
* @see AppliedStatus
*/
public ZonalShiftInResource withAppliedStatus(AppliedStatus appliedStatus) {
this.appliedStatus = appliedStatus.toString();
return this;
}
/**
*
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource when
* you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is instead
* moved to other Availability Zones in the Amazon Web Services Region.
*
*
* @param awayFrom
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource
* when you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is
* instead moved to other Availability Zones in the Amazon Web Services Region.
*/
public void setAwayFrom(String awayFrom) {
this.awayFrom = awayFrom;
}
/**
*
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource when
* you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is instead
* moved to other Availability Zones in the Amazon Web Services Region.
*
*
* @return The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource
* when you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is
* instead moved to other Availability Zones in the Amazon Web Services Region.
*/
public String getAwayFrom() {
return this.awayFrom;
}
/**
*
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource when
* you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is instead
* moved to other Availability Zones in the Amazon Web Services Region.
*
*
* @param awayFrom
* The Availability Zone (for example, use1-az1
) that traffic is moved away from for a resource
* when you start a zonal shift. Until the zonal shift expires or you cancel it, traffic for the resource is
* instead moved to other Availability Zones in the Amazon Web Services Region.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withAwayFrom(String awayFrom) {
setAwayFrom(awayFrom);
return this;
}
/**
*
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no comment
* history is maintained. That is, a new comment overwrites any existing comment string.
*
*
* @param comment
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no
* comment history is maintained. That is, a new comment overwrites any existing comment string.
*/
public void setComment(String comment) {
this.comment = comment;
}
/**
*
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no comment
* history is maintained. That is, a new comment overwrites any existing comment string.
*
*
* @return A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no
* comment history is maintained. That is, a new comment overwrites any existing comment string.
*/
public String getComment() {
return this.comment;
}
/**
*
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no comment
* history is maintained. That is, a new comment overwrites any existing comment string.
*
*
* @param comment
* A comment that you enter for a customer-initiated zonal shift. Only the latest comment is retained; no
* comment history is maintained. That is, a new comment overwrites any existing comment string.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withComment(String comment) {
setComment(comment);
return this;
}
/**
*
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and must be
* set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a maximum of three
* days (72 hours). However, you can update a zonal shift to set a new expiration at any time.
*
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts to an
* expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to the
* Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another length of
* time to expire in.
*
*
* @param expiryTime
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and
* must be set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a
* maximum of three days (72 hours). However, you can update a zonal shift to set a new expiration at any
* time.
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts
* to an expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to
* the Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another
* length of time to expire in.
*/
public void setExpiryTime(java.util.Date expiryTime) {
this.expiryTime = expiryTime;
}
/**
*
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and must be
* set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a maximum of three
* days (72 hours). However, you can update a zonal shift to set a new expiration at any time.
*
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts to an
* expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to the
* Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another length of
* time to expire in.
*
*
* @return The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and
* must be set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a
* maximum of three days (72 hours). However, you can update a zonal shift to set a new expiration at any
* time.
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts
* to an expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to
* the Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify
* another length of time to expire in.
*/
public java.util.Date getExpiryTime() {
return this.expiryTime;
}
/**
*
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and must be
* set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a maximum of three
* days (72 hours). However, you can update a zonal shift to set a new expiration at any time.
*
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts to an
* expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to the
* Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another length of
* time to expire in.
*
*
* @param expiryTime
* The expiry time (expiration time) for a customer-initiated zonal shift. A zonal shift is temporary and
* must be set to expire when you start the zonal shift. You can initially set a zonal shift to expire in a
* maximum of three days (72 hours). However, you can update a zonal shift to set a new expiration at any
* time.
*
* When you start a zonal shift, you specify how long you want it to be active, which Route 53 ARC converts
* to an expiry time (expiration time). You can cancel a zonal shift when you're ready to restore traffic to
* the Availability Zone, or just wait for it to expire. Or you can update the zonal shift to specify another
* length of time to expire in.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withExpiryTime(java.util.Date expiryTime) {
setExpiryTime(expiryTime);
return this;
}
/**
*
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does not go
* into an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal shift
* duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into an
* ALARM
state during the practice run, and the practice run was not interrupted before it completed.
*
*
*
*
* For more information about practice run outcomes, see Considerations when
* you configure zonal autoshift in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param practiceRunOutcome
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does
* not go into an ALARM
state during the practice run, and the practice run was not interrupted
* before it completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal
* shift duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into
* an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed.
*
*
*
*
* For more information about practice run outcomes, see
* Considerations when you configure zonal autoshift in the Amazon Route 53 Application Recovery
* Controller Developer Guide.
* @see PracticeRunOutcome
*/
public void setPracticeRunOutcome(String practiceRunOutcome) {
this.practiceRunOutcome = practiceRunOutcome;
}
/**
*
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does not go
* into an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal shift
* duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into an
* ALARM
state during the practice run, and the practice run was not interrupted before it completed.
*
*
*
*
* For more information about practice run outcomes, see Considerations when
* you configure zonal autoshift in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @return The outcome, or end state, returned for a practice run. The following values can be returned:
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does
* not go into an ALARM
state during the practice run, and the practice run was not interrupted
* before it completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal
* shift duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes
* into an ALARM
state during the practice run, and the practice run was not interrupted before
* it completed.
*
*
*
*
* For more information about practice run outcomes, see
* Considerations when you configure zonal autoshift in the Amazon Route 53 Application Recovery
* Controller Developer Guide.
* @see PracticeRunOutcome
*/
public String getPracticeRunOutcome() {
return this.practiceRunOutcome;
}
/**
*
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does not go
* into an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal shift
* duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into an
* ALARM
state during the practice run, and the practice run was not interrupted before it completed.
*
*
*
*
* For more information about practice run outcomes, see Considerations when
* you configure zonal autoshift in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param practiceRunOutcome
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does
* not go into an ALARM
state during the practice run, and the practice run was not interrupted
* before it completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal
* shift duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into
* an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed.
*
*
*
*
* For more information about practice run outcomes, see
* Considerations when you configure zonal autoshift in the Amazon Route 53 Application Recovery
* Controller Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
* @see PracticeRunOutcome
*/
public ZonalShiftInResource withPracticeRunOutcome(String practiceRunOutcome) {
setPracticeRunOutcome(practiceRunOutcome);
return this;
}
/**
*
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does not go
* into an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal shift
* duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into an
* ALARM
state during the practice run, and the practice run was not interrupted before it completed.
*
*
*
*
* For more information about practice run outcomes, see Considerations when
* you configure zonal autoshift in the Amazon Route 53 Application Recovery Controller Developer Guide.
*
*
* @param practiceRunOutcome
* The outcome, or end state, returned for a practice run. The following values can be returned:
*
* -
*
* PENDING: Outcome value when a practice run is in progress.
*
*
* -
*
* SUCCEEDED: Outcome value when the outcome alarm specified for the practice run configuration does
* not go into an ALARM
state during the practice run, and the practice run was not interrupted
* before it completed the expected 30 minute zonal shift.
*
*
* -
*
* INTERRUPTED: Outcome value when the practice run was stopped before the expected 30 minute zonal
* shift duration, or there was another problem with the practice run that created an inconclusive outcome.
*
*
* -
*
* FAILED: Outcome value when the outcome alarm specified for the practice run configuration goes into
* an ALARM
state during the practice run, and the practice run was not interrupted before it
* completed.
*
*
*
*
* For more information about practice run outcomes, see
* Considerations when you configure zonal autoshift in the Amazon Route 53 Application Recovery
* Controller Developer Guide.
* @return Returns a reference to this object so that method calls can be chained together.
* @see PracticeRunOutcome
*/
public ZonalShiftInResource withPracticeRunOutcome(PracticeRunOutcome practiceRunOutcome) {
this.practiceRunOutcome = practiceRunOutcome.toString();
return this;
}
/**
*
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name (ARN) for
* the resource.
*
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers with
* cross-zone load balancing turned off.
*
*
* @param resourceIdentifier
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name
* (ARN) for the resource.
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers
* with cross-zone load balancing turned off.
*/
public void setResourceIdentifier(String resourceIdentifier) {
this.resourceIdentifier = resourceIdentifier;
}
/**
*
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name (ARN) for
* the resource.
*
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers with
* cross-zone load balancing turned off.
*
*
* @return The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name
* (ARN) for the resource.
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers
* with cross-zone load balancing turned off.
*/
public String getResourceIdentifier() {
return this.resourceIdentifier;
}
/**
*
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name (ARN) for
* the resource.
*
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers with
* cross-zone load balancing turned off.
*
*
* @param resourceIdentifier
* The identifier for the resource to include in a zonal shift. The identifier is the Amazon Resource Name
* (ARN) for the resource.
*
* At this time, you can only start a zonal shift for Network Load Balancers and Application Load Balancers
* with cross-zone load balancing turned off.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withResourceIdentifier(String resourceIdentifier) {
setResourceIdentifier(resourceIdentifier);
return this;
}
/**
*
* The time (UTC) when the zonal shift starts.
*
*
* @param startTime
* The time (UTC) when the zonal shift starts.
*/
public void setStartTime(java.util.Date startTime) {
this.startTime = startTime;
}
/**
*
* The time (UTC) when the zonal shift starts.
*
*
* @return The time (UTC) when the zonal shift starts.
*/
public java.util.Date getStartTime() {
return this.startTime;
}
/**
*
* The time (UTC) when the zonal shift starts.
*
*
* @param startTime
* The time (UTC) when the zonal shift starts.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withStartTime(java.util.Date startTime) {
setStartTime(startTime);
return this;
}
/**
*
* The identifier of a zonal shift.
*
*
* @param zonalShiftId
* The identifier of a zonal shift.
*/
public void setZonalShiftId(String zonalShiftId) {
this.zonalShiftId = zonalShiftId;
}
/**
*
* The identifier of a zonal shift.
*
*
* @return The identifier of a zonal shift.
*/
public String getZonalShiftId() {
return this.zonalShiftId;
}
/**
*
* The identifier of a zonal shift.
*
*
* @param zonalShiftId
* The identifier of a zonal shift.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ZonalShiftInResource withZonalShiftId(String zonalShiftId) {
setZonalShiftId(zonalShiftId);
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getAppliedStatus() != null)
sb.append("AppliedStatus: ").append(getAppliedStatus()).append(",");
if (getAwayFrom() != null)
sb.append("AwayFrom: ").append(getAwayFrom()).append(",");
if (getComment() != null)
sb.append("Comment: ").append(getComment()).append(",");
if (getExpiryTime() != null)
sb.append("ExpiryTime: ").append(getExpiryTime()).append(",");
if (getPracticeRunOutcome() != null)
sb.append("PracticeRunOutcome: ").append(getPracticeRunOutcome()).append(",");
if (getResourceIdentifier() != null)
sb.append("ResourceIdentifier: ").append(getResourceIdentifier()).append(",");
if (getStartTime() != null)
sb.append("StartTime: ").append(getStartTime()).append(",");
if (getZonalShiftId() != null)
sb.append("ZonalShiftId: ").append(getZonalShiftId());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ZonalShiftInResource == false)
return false;
ZonalShiftInResource other = (ZonalShiftInResource) obj;
if (other.getAppliedStatus() == null ^ this.getAppliedStatus() == null)
return false;
if (other.getAppliedStatus() != null && other.getAppliedStatus().equals(this.getAppliedStatus()) == false)
return false;
if (other.getAwayFrom() == null ^ this.getAwayFrom() == null)
return false;
if (other.getAwayFrom() != null && other.getAwayFrom().equals(this.getAwayFrom()) == false)
return false;
if (other.getComment() == null ^ this.getComment() == null)
return false;
if (other.getComment() != null && other.getComment().equals(this.getComment()) == false)
return false;
if (other.getExpiryTime() == null ^ this.getExpiryTime() == null)
return false;
if (other.getExpiryTime() != null && other.getExpiryTime().equals(this.getExpiryTime()) == false)
return false;
if (other.getPracticeRunOutcome() == null ^ this.getPracticeRunOutcome() == null)
return false;
if (other.getPracticeRunOutcome() != null && other.getPracticeRunOutcome().equals(this.getPracticeRunOutcome()) == false)
return false;
if (other.getResourceIdentifier() == null ^ this.getResourceIdentifier() == null)
return false;
if (other.getResourceIdentifier() != null && other.getResourceIdentifier().equals(this.getResourceIdentifier()) == false)
return false;
if (other.getStartTime() == null ^ this.getStartTime() == null)
return false;
if (other.getStartTime() != null && other.getStartTime().equals(this.getStartTime()) == false)
return false;
if (other.getZonalShiftId() == null ^ this.getZonalShiftId() == null)
return false;
if (other.getZonalShiftId() != null && other.getZonalShiftId().equals(this.getZonalShiftId()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAppliedStatus() == null) ? 0 : getAppliedStatus().hashCode());
hashCode = prime * hashCode + ((getAwayFrom() == null) ? 0 : getAwayFrom().hashCode());
hashCode = prime * hashCode + ((getComment() == null) ? 0 : getComment().hashCode());
hashCode = prime * hashCode + ((getExpiryTime() == null) ? 0 : getExpiryTime().hashCode());
hashCode = prime * hashCode + ((getPracticeRunOutcome() == null) ? 0 : getPracticeRunOutcome().hashCode());
hashCode = prime * hashCode + ((getResourceIdentifier() == null) ? 0 : getResourceIdentifier().hashCode());
hashCode = prime * hashCode + ((getStartTime() == null) ? 0 : getStartTime().hashCode());
hashCode = prime * hashCode + ((getZonalShiftId() == null) ? 0 : getZonalShiftId().hashCode());
return hashCode;
}
@Override
public ZonalShiftInResource clone() {
try {
return (ZonalShiftInResource) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.arczonalshift.model.transform.ZonalShiftInResourceMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}