com.amazonaws.services.directconnect.model.Lag Maven / Gradle / Ivy
Show all versions of aws-java-sdk-directconnect Show documentation
/*
* Copyright 2012-2017 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.directconnect.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Describes a link aggregation group (LAG). A LAG is a connection that uses the Link Aggregation Control Protocol
* (LACP) to logically aggregate a bundle of physical connections. Like an interconnect, it can host other connections.
* All connections in a LAG must terminate on the same physical AWS Direct Connect endpoint, and must be the same
* bandwidth.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Lag implements Serializable, Cloneable, StructuredPojo {
/**
*
* The individual bandwidth of the physical connections bundled by the LAG.
*
*
* Available values: 1Gbps, 10Gbps
*
*/
private String connectionsBandwidth;
/**
*
* The number of physical connections bundled by the LAG, up to a maximum of 10.
*
*/
private Integer numberOfConnections;
private String lagId;
/**
*
* The owner of the LAG.
*
*/
private String ownerAccount;
/**
*
* The name of the LAG.
*
*/
private String lagName;
private String lagState;
private String location;
private String region;
/**
*
* The minimum number of physical connections that must be operational for the LAG itself to be operational. If the
* number of operational connections drops below this setting, the LAG state changes to down
. This
* value can help to ensure that a LAG is not overutilized if a significant number of its bundled connections go
* down.
*
*/
private Integer minimumLinks;
/**
*
* The AWS Direct Connection endpoint that hosts the LAG.
*
*/
private String awsDevice;
/**
*
* A list of connections bundled by this LAG.
*
*/
private com.amazonaws.internal.SdkInternalList connections;
/**
*
* Indicates whether the LAG can host other connections.
*
*
*
* This is intended for use by AWS Direct Connect partners only.
*
*
*/
private Boolean allowsHostedConnections;
/**
*
* The individual bandwidth of the physical connections bundled by the LAG.
*
*
* Available values: 1Gbps, 10Gbps
*
*
* @param connectionsBandwidth
* The individual bandwidth of the physical connections bundled by the LAG.
*
* Available values: 1Gbps, 10Gbps
*/
public void setConnectionsBandwidth(String connectionsBandwidth) {
this.connectionsBandwidth = connectionsBandwidth;
}
/**
*
* The individual bandwidth of the physical connections bundled by the LAG.
*
*
* Available values: 1Gbps, 10Gbps
*
*
* @return The individual bandwidth of the physical connections bundled by the LAG.
*
* Available values: 1Gbps, 10Gbps
*/
public String getConnectionsBandwidth() {
return this.connectionsBandwidth;
}
/**
*
* The individual bandwidth of the physical connections bundled by the LAG.
*
*
* Available values: 1Gbps, 10Gbps
*
*
* @param connectionsBandwidth
* The individual bandwidth of the physical connections bundled by the LAG.
*
* Available values: 1Gbps, 10Gbps
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withConnectionsBandwidth(String connectionsBandwidth) {
setConnectionsBandwidth(connectionsBandwidth);
return this;
}
/**
*
* The number of physical connections bundled by the LAG, up to a maximum of 10.
*
*
* @param numberOfConnections
* The number of physical connections bundled by the LAG, up to a maximum of 10.
*/
public void setNumberOfConnections(Integer numberOfConnections) {
this.numberOfConnections = numberOfConnections;
}
/**
*
* The number of physical connections bundled by the LAG, up to a maximum of 10.
*
*
* @return The number of physical connections bundled by the LAG, up to a maximum of 10.
*/
public Integer getNumberOfConnections() {
return this.numberOfConnections;
}
/**
*
* The number of physical connections bundled by the LAG, up to a maximum of 10.
*
*
* @param numberOfConnections
* The number of physical connections bundled by the LAG, up to a maximum of 10.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withNumberOfConnections(Integer numberOfConnections) {
setNumberOfConnections(numberOfConnections);
return this;
}
/**
* @param lagId
*/
public void setLagId(String lagId) {
this.lagId = lagId;
}
/**
* @return
*/
public String getLagId() {
return this.lagId;
}
/**
* @param lagId
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withLagId(String lagId) {
setLagId(lagId);
return this;
}
/**
*
* The owner of the LAG.
*
*
* @param ownerAccount
* The owner of the LAG.
*/
public void setOwnerAccount(String ownerAccount) {
this.ownerAccount = ownerAccount;
}
/**
*
* The owner of the LAG.
*
*
* @return The owner of the LAG.
*/
public String getOwnerAccount() {
return this.ownerAccount;
}
/**
*
* The owner of the LAG.
*
*
* @param ownerAccount
* The owner of the LAG.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withOwnerAccount(String ownerAccount) {
setOwnerAccount(ownerAccount);
return this;
}
/**
*
* The name of the LAG.
*
*
* @param lagName
* The name of the LAG.
*/
public void setLagName(String lagName) {
this.lagName = lagName;
}
/**
*
* The name of the LAG.
*
*
* @return The name of the LAG.
*/
public String getLagName() {
return this.lagName;
}
/**
*
* The name of the LAG.
*
*
* @param lagName
* The name of the LAG.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withLagName(String lagName) {
setLagName(lagName);
return this;
}
/**
* @param lagState
* @see LagState
*/
public void setLagState(String lagState) {
this.lagState = lagState;
}
/**
* @return
* @see LagState
*/
public String getLagState() {
return this.lagState;
}
/**
* @param lagState
* @return Returns a reference to this object so that method calls can be chained together.
* @see LagState
*/
public Lag withLagState(String lagState) {
setLagState(lagState);
return this;
}
/**
* @param lagState
* @see LagState
*/
public void setLagState(LagState lagState) {
withLagState(lagState);
}
/**
* @param lagState
* @return Returns a reference to this object so that method calls can be chained together.
* @see LagState
*/
public Lag withLagState(LagState lagState) {
this.lagState = lagState.toString();
return this;
}
/**
* @param location
*/
public void setLocation(String location) {
this.location = location;
}
/**
* @return
*/
public String getLocation() {
return this.location;
}
/**
* @param location
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withLocation(String location) {
setLocation(location);
return this;
}
/**
* @param region
*/
public void setRegion(String region) {
this.region = region;
}
/**
* @return
*/
public String getRegion() {
return this.region;
}
/**
* @param region
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withRegion(String region) {
setRegion(region);
return this;
}
/**
*
* The minimum number of physical connections that must be operational for the LAG itself to be operational. If the
* number of operational connections drops below this setting, the LAG state changes to down
. This
* value can help to ensure that a LAG is not overutilized if a significant number of its bundled connections go
* down.
*
*
* @param minimumLinks
* The minimum number of physical connections that must be operational for the LAG itself to be operational.
* If the number of operational connections drops below this setting, the LAG state changes to
* down
. This value can help to ensure that a LAG is not overutilized if a significant number of
* its bundled connections go down.
*/
public void setMinimumLinks(Integer minimumLinks) {
this.minimumLinks = minimumLinks;
}
/**
*
* The minimum number of physical connections that must be operational for the LAG itself to be operational. If the
* number of operational connections drops below this setting, the LAG state changes to down
. This
* value can help to ensure that a LAG is not overutilized if a significant number of its bundled connections go
* down.
*
*
* @return The minimum number of physical connections that must be operational for the LAG itself to be operational.
* If the number of operational connections drops below this setting, the LAG state changes to
* down
. This value can help to ensure that a LAG is not overutilized if a significant number
* of its bundled connections go down.
*/
public Integer getMinimumLinks() {
return this.minimumLinks;
}
/**
*
* The minimum number of physical connections that must be operational for the LAG itself to be operational. If the
* number of operational connections drops below this setting, the LAG state changes to down
. This
* value can help to ensure that a LAG is not overutilized if a significant number of its bundled connections go
* down.
*
*
* @param minimumLinks
* The minimum number of physical connections that must be operational for the LAG itself to be operational.
* If the number of operational connections drops below this setting, the LAG state changes to
* down
. This value can help to ensure that a LAG is not overutilized if a significant number of
* its bundled connections go down.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withMinimumLinks(Integer minimumLinks) {
setMinimumLinks(minimumLinks);
return this;
}
/**
*
* The AWS Direct Connection endpoint that hosts the LAG.
*
*
* @param awsDevice
* The AWS Direct Connection endpoint that hosts the LAG.
*/
public void setAwsDevice(String awsDevice) {
this.awsDevice = awsDevice;
}
/**
*
* The AWS Direct Connection endpoint that hosts the LAG.
*
*
* @return The AWS Direct Connection endpoint that hosts the LAG.
*/
public String getAwsDevice() {
return this.awsDevice;
}
/**
*
* The AWS Direct Connection endpoint that hosts the LAG.
*
*
* @param awsDevice
* The AWS Direct Connection endpoint that hosts the LAG.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withAwsDevice(String awsDevice) {
setAwsDevice(awsDevice);
return this;
}
/**
*
* A list of connections bundled by this LAG.
*
*
* @return A list of connections bundled by this LAG.
*/
public java.util.List getConnections() {
if (connections == null) {
connections = new com.amazonaws.internal.SdkInternalList();
}
return connections;
}
/**
*
* A list of connections bundled by this LAG.
*
*
* @param connections
* A list of connections bundled by this LAG.
*/
public void setConnections(java.util.Collection connections) {
if (connections == null) {
this.connections = null;
return;
}
this.connections = new com.amazonaws.internal.SdkInternalList(connections);
}
/**
*
* A list of connections bundled by this LAG.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setConnections(java.util.Collection)} or {@link #withConnections(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param connections
* A list of connections bundled by this LAG.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withConnections(Connection... connections) {
if (this.connections == null) {
setConnections(new com.amazonaws.internal.SdkInternalList(connections.length));
}
for (Connection ele : connections) {
this.connections.add(ele);
}
return this;
}
/**
*
* A list of connections bundled by this LAG.
*
*
* @param connections
* A list of connections bundled by this LAG.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withConnections(java.util.Collection connections) {
setConnections(connections);
return this;
}
/**
*
* Indicates whether the LAG can host other connections.
*
*
*
* This is intended for use by AWS Direct Connect partners only.
*
*
*
* @param allowsHostedConnections
* Indicates whether the LAG can host other connections.
*
* This is intended for use by AWS Direct Connect partners only.
*
*/
public void setAllowsHostedConnections(Boolean allowsHostedConnections) {
this.allowsHostedConnections = allowsHostedConnections;
}
/**
*
* Indicates whether the LAG can host other connections.
*
*
*
* This is intended for use by AWS Direct Connect partners only.
*
*
*
* @return Indicates whether the LAG can host other connections.
*
* This is intended for use by AWS Direct Connect partners only.
*
*/
public Boolean getAllowsHostedConnections() {
return this.allowsHostedConnections;
}
/**
*
* Indicates whether the LAG can host other connections.
*
*
*
* This is intended for use by AWS Direct Connect partners only.
*
*
*
* @param allowsHostedConnections
* Indicates whether the LAG can host other connections.
*
* This is intended for use by AWS Direct Connect partners only.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Lag withAllowsHostedConnections(Boolean allowsHostedConnections) {
setAllowsHostedConnections(allowsHostedConnections);
return this;
}
/**
*
* Indicates whether the LAG can host other connections.
*
*
*
* This is intended for use by AWS Direct Connect partners only.
*
*
*
* @return Indicates whether the LAG can host other connections.
*
* This is intended for use by AWS Direct Connect partners only.
*
*/
public Boolean isAllowsHostedConnections() {
return this.allowsHostedConnections;
}
/**
* Returns a string representation of this object; useful for testing and debugging.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getConnectionsBandwidth() != null)
sb.append("ConnectionsBandwidth: ").append(getConnectionsBandwidth()).append(",");
if (getNumberOfConnections() != null)
sb.append("NumberOfConnections: ").append(getNumberOfConnections()).append(",");
if (getLagId() != null)
sb.append("LagId: ").append(getLagId()).append(",");
if (getOwnerAccount() != null)
sb.append("OwnerAccount: ").append(getOwnerAccount()).append(",");
if (getLagName() != null)
sb.append("LagName: ").append(getLagName()).append(",");
if (getLagState() != null)
sb.append("LagState: ").append(getLagState()).append(",");
if (getLocation() != null)
sb.append("Location: ").append(getLocation()).append(",");
if (getRegion() != null)
sb.append("Region: ").append(getRegion()).append(",");
if (getMinimumLinks() != null)
sb.append("MinimumLinks: ").append(getMinimumLinks()).append(",");
if (getAwsDevice() != null)
sb.append("AwsDevice: ").append(getAwsDevice()).append(",");
if (getConnections() != null)
sb.append("Connections: ").append(getConnections()).append(",");
if (getAllowsHostedConnections() != null)
sb.append("AllowsHostedConnections: ").append(getAllowsHostedConnections());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof Lag == false)
return false;
Lag other = (Lag) obj;
if (other.getConnectionsBandwidth() == null ^ this.getConnectionsBandwidth() == null)
return false;
if (other.getConnectionsBandwidth() != null && other.getConnectionsBandwidth().equals(this.getConnectionsBandwidth()) == false)
return false;
if (other.getNumberOfConnections() == null ^ this.getNumberOfConnections() == null)
return false;
if (other.getNumberOfConnections() != null && other.getNumberOfConnections().equals(this.getNumberOfConnections()) == false)
return false;
if (other.getLagId() == null ^ this.getLagId() == null)
return false;
if (other.getLagId() != null && other.getLagId().equals(this.getLagId()) == false)
return false;
if (other.getOwnerAccount() == null ^ this.getOwnerAccount() == null)
return false;
if (other.getOwnerAccount() != null && other.getOwnerAccount().equals(this.getOwnerAccount()) == false)
return false;
if (other.getLagName() == null ^ this.getLagName() == null)
return false;
if (other.getLagName() != null && other.getLagName().equals(this.getLagName()) == false)
return false;
if (other.getLagState() == null ^ this.getLagState() == null)
return false;
if (other.getLagState() != null && other.getLagState().equals(this.getLagState()) == false)
return false;
if (other.getLocation() == null ^ this.getLocation() == null)
return false;
if (other.getLocation() != null && other.getLocation().equals(this.getLocation()) == false)
return false;
if (other.getRegion() == null ^ this.getRegion() == null)
return false;
if (other.getRegion() != null && other.getRegion().equals(this.getRegion()) == false)
return false;
if (other.getMinimumLinks() == null ^ this.getMinimumLinks() == null)
return false;
if (other.getMinimumLinks() != null && other.getMinimumLinks().equals(this.getMinimumLinks()) == false)
return false;
if (other.getAwsDevice() == null ^ this.getAwsDevice() == null)
return false;
if (other.getAwsDevice() != null && other.getAwsDevice().equals(this.getAwsDevice()) == false)
return false;
if (other.getConnections() == null ^ this.getConnections() == null)
return false;
if (other.getConnections() != null && other.getConnections().equals(this.getConnections()) == false)
return false;
if (other.getAllowsHostedConnections() == null ^ this.getAllowsHostedConnections() == null)
return false;
if (other.getAllowsHostedConnections() != null && other.getAllowsHostedConnections().equals(this.getAllowsHostedConnections()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getConnectionsBandwidth() == null) ? 0 : getConnectionsBandwidth().hashCode());
hashCode = prime * hashCode + ((getNumberOfConnections() == null) ? 0 : getNumberOfConnections().hashCode());
hashCode = prime * hashCode + ((getLagId() == null) ? 0 : getLagId().hashCode());
hashCode = prime * hashCode + ((getOwnerAccount() == null) ? 0 : getOwnerAccount().hashCode());
hashCode = prime * hashCode + ((getLagName() == null) ? 0 : getLagName().hashCode());
hashCode = prime * hashCode + ((getLagState() == null) ? 0 : getLagState().hashCode());
hashCode = prime * hashCode + ((getLocation() == null) ? 0 : getLocation().hashCode());
hashCode = prime * hashCode + ((getRegion() == null) ? 0 : getRegion().hashCode());
hashCode = prime * hashCode + ((getMinimumLinks() == null) ? 0 : getMinimumLinks().hashCode());
hashCode = prime * hashCode + ((getAwsDevice() == null) ? 0 : getAwsDevice().hashCode());
hashCode = prime * hashCode + ((getConnections() == null) ? 0 : getConnections().hashCode());
hashCode = prime * hashCode + ((getAllowsHostedConnections() == null) ? 0 : getAllowsHostedConnections().hashCode());
return hashCode;
}
@Override
public Lag clone() {
try {
return (Lag) 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.directconnect.model.transform.LagMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}