All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.solidfire.element.api.StartVolumePairingRequest Maven / Gradle / Ivy

There is a newer version: 1.5.0.89
Show 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.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;


/**
 * The Request object for the "StartVolumePairing" API Service call.
 **/
public class StartVolumePairingRequest  implements Serializable  {

    private static final long serialVersionUID = -317356972L;

    @SerializedName("volumeID") private final Long volumeID;
    @SerializedName("mode") private final Optional mode;

    /**
     * The Request object for the "StartVolumePairing" API Service call.
     * @param volumeID [required] The ID of the volume on which to start the pairing process.
     * @since 7.0
     **/
    @Since("7.0")
    public StartVolumePairingRequest(Long volumeID) {
        this.volumeID = volumeID;
        this.mode = Optional.empty();
    }

    /**
     * The Request object for the "StartVolumePairing" API Service call.
     * @param volumeID [required] The ID of the volume on which to start the pairing process.
     * @param mode (optional) 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.
* @since 8.0 **/ @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; } /** * 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:
* 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 will not be replicated.
* @since 8.0 **/ @Since("8.0") public Optional getMode() { return this.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 ); } @Override public String toString() { final StringBuilder sb = new StringBuilder(); sb.append( "{ " ); sb.append(" volumeID : ").append(volumeID).append(","); if(null != mode && mode.isPresent()) sb.append(" mode : ").append(mode.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 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; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy