com.solidfire.element.api.StartVolumePairingRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of solidfire-sdk-java Show documentation
Show all versions of solidfire-sdk-java Show documentation
Library for interfacing with the Public and Incubating SolidFire Element API.
The newest version!
/*
* Copyright © 2014-2016 NetApp, Inc. 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.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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.
*/
/*
* DO NOT EDIT THIS CODE BY HAND! It has been generated with jsvcgen.
*/
package com.solidfire.element.api;
import com.solidfire.gson.Gson;
import com.solidfire.core.client.Attributes;
import com.solidfire.gson.annotations.SerializedName;
import com.solidfire.core.annotation.Since;
import com.solidfire.core.javautil.Optional;
import java.io.Serializable;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Objects;
/**
* StartVolumePairingRequest
* StartVolumePairing enables you to create an encoded key from a volume that is used to pair with another volume. The key that this
* method creates is used in the CompleteVolumePairing API method to establish a volume pairing.
**/
public class StartVolumePairingRequest implements Serializable {
public static final long serialVersionUID = -2380012139817761596L;
@SerializedName("volumeID") private Long volumeID;
@SerializedName("mode") private Optional mode;
// empty constructor
@Since("7.0")
public StartVolumePairingRequest() {}
// parameterized constructor
@Since("7.0")
public StartVolumePairingRequest(
Long volumeID
)
{
this.volumeID = volumeID;
}
// parameterized constructor
@Since("8.0")
public StartVolumePairingRequest(
Long volumeID,
Optional mode
)
{
this.volumeID = volumeID;
this.mode = (mode == null) ? Optional.empty() : mode;
}
/**
* The ID of the volume on which to start the pairing process.
**/
public Long getVolumeID() { return this.volumeID; }
public void setVolumeID(Long volumeID) {
this.volumeID = volumeID;
}
/**
* The mode of the volume on which to start the pairing process. The mode can only be set if the volume is the source volume. Possible values are: Async: (default if no mode parameter specified) Writes are acknowledged when they complete locally. The cluster does not wait for writes to be replicated to the target cluster. Sync: Source acknowledges write when the data is stored locally and on the remote cluster. SnapshotsOnly: Only snapshots created on the source cluster will be replicated. Active writes from the source volume are not replicated.
**/
public Optional getMode() { return this.mode; }
public void setMode(Optional mode) {
this.mode = (mode == null) ? Optional.empty() : mode;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
StartVolumePairingRequest that = (StartVolumePairingRequest) o;
return
Objects.equals(volumeID, that.volumeID) &&
Objects.equals(mode, that.mode);
}
@Override
public int hashCode() {
return Objects.hash( volumeID,mode );
}
public java.util.Map toMap() {
java.util.Map map = new HashMap<>();
map.put("volumeID", volumeID);
map.put("mode", mode);
return map;
}
@Override
public String toString() {
final StringBuilder sb = new StringBuilder();
Gson gson = new Gson();
sb.append( "{ " );
sb.append(" volumeID : ").append(gson.toJson(volumeID)).append(",");
if(null != mode && mode.isPresent()){
sb.append(" mode : ").append(gson.toJson(mode)).append(",");
}
else{
sb.append(" mode : ").append("null").append(",");
}
sb.append( " }" );
if(sb.lastIndexOf(", }") != -1)
sb.deleteCharAt(sb.lastIndexOf(", }"));
return sb.toString();
}
public static Builder builder() {
return new Builder();
}
public final Builder asBuilder() {
return new Builder().buildFrom(this);
}
public static class Builder {
private Long volumeID;
private Optional mode;
private Builder() { }
public StartVolumePairingRequest build() {
return new StartVolumePairingRequest (
this.volumeID,
this.mode);
}
private StartVolumePairingRequest.Builder buildFrom(final StartVolumePairingRequest req) {
this.volumeID = req.volumeID;
this.mode = req.mode;
return this;
}
public StartVolumePairingRequest.Builder volumeID(final Long volumeID) {
this.volumeID = volumeID;
return this;
}
public StartVolumePairingRequest.Builder optionalMode(final String mode) {
this.mode = (mode == null) ? Optional.empty() : Optional.of(mode);
return this;
}
}
}