com.solidfire.element.api.ScheduleInfo 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.
/*
* 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.annotations.SerializedName;
import com.solidfire.jsvcgen.annotation.Since;
import com.solidfire.jsvcgen.client.ApiException;
import com.solidfire.jsvcgen.javautil.Optional;
import java.net.URL;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Objects;
import java.util.TreeMap;
import static com.solidfire.jsvcgen.javautil.Optional.of;
/**
*
**/
public class ScheduleInfo implements Serializable {
private static final long serialVersionUID = 1971104557L;
@SerializedName("volumeIDs") private final Optional volumeIDs;
@SerializedName("snapshotName") private final Optional snapshotName;
@SerializedName("enableRemoteReplication") private final Optional enableRemoteReplication;
@SerializedName("retention") private final Optional retention;
/**
*
* @param volumeIDs (optional) A list of volume IDs to be included in the group snapshot.
* @param snapshotName (optional) The snapshot name to be used.
* @param enableRemoteReplication (optional) Indicates if the snapshot should be included in remote replication.
* @param retention (optional) The amount of time the snapshot will be retained in HH:mm:ss.
* @since 7.0
**/
@Since("7.0")
public ScheduleInfo(Optional volumeIDs, Optional snapshotName, Optional enableRemoteReplication, Optional retention) {
this.volumeIDs = (volumeIDs == null) ? Optional.empty() : volumeIDs;
this.snapshotName = (snapshotName == null) ? Optional.empty() : snapshotName;
this.enableRemoteReplication = (enableRemoteReplication == null) ? Optional.empty() : enableRemoteReplication;
this.retention = (retention == null) ? Optional.empty() : retention;
}
/**
* A list of volume IDs to be included in the group snapshot.
**/
public Optional getVolumeIDs() {
return this.volumeIDs;
}
/**
* The snapshot name to be used.
**/
public Optional getSnapshotName() {
return this.snapshotName;
}
/**
* Indicates if the snapshot should be included in remote replication.
**/
public Optional getEnableRemoteReplication() {
return this.enableRemoteReplication;
}
/**
* The amount of time the snapshot will be retained in HH:mm:ss.
**/
public Optional getRetention() {
return this.retention;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
ScheduleInfo that = (ScheduleInfo) o;
return Objects.deepEquals( volumeIDs , that.volumeIDs )
&& Objects.equals( snapshotName , that.snapshotName )
&& Objects.equals( enableRemoteReplication , that.enableRemoteReplication )
&& Objects.equals( retention , that.retention );
}
@Override
public int hashCode() {
return Objects.hash( volumeIDs, snapshotName, enableRemoteReplication, retention );
}
@Override
public String toString() {
final StringBuilder sb = new StringBuilder();
sb.append( "{ " );
if(null != volumeIDs && volumeIDs.isPresent())
sb.append(" volumeIDs : ").append(Arrays.toString(volumeIDs.get())).append(",");
if(null != snapshotName && snapshotName.isPresent())
sb.append(" snapshotName : ").append(snapshotName.get()).append(",");
if(null != enableRemoteReplication && enableRemoteReplication.isPresent())
sb.append(" enableRemoteReplication : ").append(enableRemoteReplication.get()).append(",");
if(null != retention && retention.isPresent())
sb.append(" retention : ").append(retention.get());
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 Optional volumeIDs;
private Optional snapshotName;
private Optional enableRemoteReplication;
private Optional retention;
private Builder() { }
public ScheduleInfo build() {
return new ScheduleInfo (
this.volumeIDs,
this.snapshotName,
this.enableRemoteReplication,
this.retention );
}
private ScheduleInfo.Builder buildFrom(final ScheduleInfo req) {
this.volumeIDs = req.volumeIDs;
this.snapshotName = req.snapshotName;
this.enableRemoteReplication = req.enableRemoteReplication;
this.retention = req.retention;
return this;
}
public ScheduleInfo.Builder optionalVolumeIDs(final Long[] volumeIDs) {
this.volumeIDs = (volumeIDs == null) ? Optional.empty() : Optional.of(volumeIDs);
return this;
}
public ScheduleInfo.Builder optionalSnapshotName(final String snapshotName) {
this.snapshotName = (snapshotName == null) ? Optional.empty() : Optional.of(snapshotName);
return this;
}
public ScheduleInfo.Builder optionalEnableRemoteReplication(final Boolean enableRemoteReplication) {
this.enableRemoteReplication = (enableRemoteReplication == null) ? Optional.empty() : Optional.of(enableRemoteReplication);
return this;
}
public ScheduleInfo.Builder optionalRetention(final String retention) {
this.retention = (retention == null) ? Optional.empty() : Optional.of(retention);
return this;
}
}
}