
software.amazon.awssdk.services.directconnect.model.AssociateMacSecKeyRequest Maven / Gradle / Ivy
/*
* Copyright 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 software.amazon.awssdk.services.directconnect.model;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class AssociateMacSecKeyRequest extends DirectConnectRequest implements
ToCopyableBuilder {
private static final SdkField CONNECTION_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("connectionId").getter(getter(AssociateMacSecKeyRequest::connectionId))
.setter(setter(Builder::connectionId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("connectionId").build()).build();
private static final SdkField SECRET_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("secretARN").getter(getter(AssociateMacSecKeyRequest::secretARN)).setter(setter(Builder::secretARN))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("secretARN").build()).build();
private static final SdkField CKN_FIELD = SdkField. builder(MarshallingType.STRING).memberName("ckn")
.getter(getter(AssociateMacSecKeyRequest::ckn)).setter(setter(Builder::ckn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ckn").build()).build();
private static final SdkField CAK_FIELD = SdkField. builder(MarshallingType.STRING).memberName("cak")
.getter(getter(AssociateMacSecKeyRequest::cak)).setter(setter(Builder::cak))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("cak").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CONNECTION_ID_FIELD,
SECRET_ARN_FIELD, CKN_FIELD, CAK_FIELD));
private final String connectionId;
private final String secretARN;
private final String ckn;
private final String cak;
private AssociateMacSecKeyRequest(BuilderImpl builder) {
super(builder);
this.connectionId = builder.connectionId;
this.secretARN = builder.secretARN;
this.ckn = builder.ckn;
this.cak = builder.cak;
}
/**
*
* The ID of the dedicated connection (dxcon-xxxx), or the ID of the LAG (dxlag-xxxx).
*
*
* You can use DescribeConnections or DescribeLags to retrieve connection ID.
*
*
* @return The ID of the dedicated connection (dxcon-xxxx), or the ID of the LAG (dxlag-xxxx).
*
* You can use DescribeConnections or DescribeLags to retrieve connection ID.
*/
public final String connectionId() {
return connectionId;
}
/**
*
* The Amazon Resource Name (ARN) of the MAC Security (MACsec) secret key to associate with the dedicated
* connection.
*
*
* You can use DescribeConnections or DescribeLags to retrieve the MAC Security (MACsec) secret key.
*
*
* If you use this request parameter, you do not use the ckn
and cak
request parameters.
*
*
* @return The Amazon Resource Name (ARN) of the MAC Security (MACsec) secret key to associate with the dedicated
* connection.
*
* You can use DescribeConnections or DescribeLags to retrieve the MAC Security (MACsec)
* secret key.
*
*
* If you use this request parameter, you do not use the ckn
and cak
request
* parameters.
*/
public final String secretARN() {
return secretARN;
}
/**
*
* The MAC Security (MACsec) CKN to associate with the dedicated connection.
*
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the cak
request parameter and not use the
* secretARN
request parameter.
*
*
* @return The MAC Security (MACsec) CKN to associate with the dedicated connection.
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the cak
request parameter and not use the
* secretARN
request parameter.
*/
public final String ckn() {
return ckn;
}
/**
*
* The MAC Security (MACsec) CAK to associate with the dedicated connection.
*
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the ckn
request parameter and not use the
* secretARN
request parameter.
*
*
* @return The MAC Security (MACsec) CAK to associate with the dedicated connection.
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the ckn
request parameter and not use the
* secretARN
request parameter.
*/
public final String cak() {
return cak;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(connectionId());
hashCode = 31 * hashCode + Objects.hashCode(secretARN());
hashCode = 31 * hashCode + Objects.hashCode(ckn());
hashCode = 31 * hashCode + Objects.hashCode(cak());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof AssociateMacSecKeyRequest)) {
return false;
}
AssociateMacSecKeyRequest other = (AssociateMacSecKeyRequest) obj;
return Objects.equals(connectionId(), other.connectionId()) && Objects.equals(secretARN(), other.secretARN())
&& Objects.equals(ckn(), other.ckn()) && Objects.equals(cak(), other.cak());
}
/**
* 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.
*/
@Override
public final String toString() {
return ToString.builder("AssociateMacSecKeyRequest").add("ConnectionId", connectionId()).add("SecretARN", secretARN())
.add("Ckn", ckn()).add("Cak", cak()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "connectionId":
return Optional.ofNullable(clazz.cast(connectionId()));
case "secretARN":
return Optional.ofNullable(clazz.cast(secretARN()));
case "ckn":
return Optional.ofNullable(clazz.cast(ckn()));
case "cak":
return Optional.ofNullable(clazz.cast(cak()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function
*
* You can use DescribeConnections or DescribeLags to retrieve connection ID.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder connectionId(String connectionId);
/**
*
* The Amazon Resource Name (ARN) of the MAC Security (MACsec) secret key to associate with the dedicated
* connection.
*
*
* You can use DescribeConnections or DescribeLags to retrieve the MAC Security (MACsec) secret
* key.
*
*
* If you use this request parameter, you do not use the ckn
and cak
request
* parameters.
*
*
* @param secretARN
* The Amazon Resource Name (ARN) of the MAC Security (MACsec) secret key to associate with the dedicated
* connection.
*
* You can use DescribeConnections or DescribeLags to retrieve the MAC Security (MACsec)
* secret key.
*
*
* If you use this request parameter, you do not use the ckn
and cak
request
* parameters.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder secretARN(String secretARN);
/**
*
* The MAC Security (MACsec) CKN to associate with the dedicated connection.
*
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the cak
request parameter and not use the
* secretARN
request parameter.
*
*
* @param ckn
* The MAC Security (MACsec) CKN to associate with the dedicated connection.
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the cak
request parameter and not use the
* secretARN
request parameter.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder ckn(String ckn);
/**
*
* The MAC Security (MACsec) CAK to associate with the dedicated connection.
*
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the ckn
request parameter and not use the
* secretARN
request parameter.
*
*
* @param cak
* The MAC Security (MACsec) CAK to associate with the dedicated connection.
*
* You can create the CKN/CAK pair using an industry standard tool.
*
*
* The valid values are 64 hexadecimal characters (0-9, A-E).
*
*
* If you use this request parameter, you must use the ckn
request parameter and not use the
* secretARN
request parameter.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder cak(String cak);
@Override
Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration);
@Override
Builder overrideConfiguration(Consumer builderConsumer);
}
static final class BuilderImpl extends DirectConnectRequest.BuilderImpl implements Builder {
private String connectionId;
private String secretARN;
private String ckn;
private String cak;
private BuilderImpl() {
}
private BuilderImpl(AssociateMacSecKeyRequest model) {
super(model);
connectionId(model.connectionId);
secretARN(model.secretARN);
ckn(model.ckn);
cak(model.cak);
}
public final String getConnectionId() {
return connectionId;
}
public final void setConnectionId(String connectionId) {
this.connectionId = connectionId;
}
@Override
public final Builder connectionId(String connectionId) {
this.connectionId = connectionId;
return this;
}
public final String getSecretARN() {
return secretARN;
}
public final void setSecretARN(String secretARN) {
this.secretARN = secretARN;
}
@Override
public final Builder secretARN(String secretARN) {
this.secretARN = secretARN;
return this;
}
public final String getCkn() {
return ckn;
}
public final void setCkn(String ckn) {
this.ckn = ckn;
}
@Override
public final Builder ckn(String ckn) {
this.ckn = ckn;
return this;
}
public final String getCak() {
return cak;
}
public final void setCak(String cak) {
this.cak = cak;
}
@Override
public final Builder cak(String cak) {
this.cak = cak;
return this;
}
@Override
public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) {
super.overrideConfiguration(overrideConfiguration);
return this;
}
@Override
public Builder overrideConfiguration(Consumer builderConsumer) {
super.overrideConfiguration(builderConsumer);
return this;
}
@Override
public AssociateMacSecKeyRequest build() {
return new AssociateMacSecKeyRequest(this);
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
}
}