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

com.solidfire.element.api.VolumeAccessGroup 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;


/**
 * A volume access group is a useful way of grouping volumes and initiators together for ease of management.
 **/
public class VolumeAccessGroup  implements Serializable  {

    private static final long serialVersionUID = 936271874L;

    @SerializedName("volumeAccessGroupID") private final Long volumeAccessGroupID;
    @SerializedName("name") private final String name;
    @SerializedName("initiators") private final String[] initiators;
    @SerializedName("volumes") private final Long[] volumes;

    /**
     * A volume access group is a useful way of grouping volumes and initiators together for ease of management.
     * 

* Volume Access Group Limits: *

* - A volume access group can contain up to sixty-four initiator IQNs. * - An initiator can only belong to only one volume access group. * - A volume access group can contain up to two thousand volumes. * - Each volume access group can belong to a maximum of four other volume access groups. * @param volumeAccessGroupID [required] Unique ID for this volume access group. * @param name [required] Name of the volume access group. * @param initiators [required] List of unique initiator names belonging to the volume access group. * @param volumes [required] List of volumes belonging to the volume access group. * @since 7.0 **/ @Since("7.0") public VolumeAccessGroup(Long volumeAccessGroupID, String name, String[] initiators, Long[] volumes) { this.volumeAccessGroupID = volumeAccessGroupID; this.name = name; this.initiators = initiators; this.volumes = volumes; } /** * Unique ID for this volume access group. **/ public Long getVolumeAccessGroupID() { return this.volumeAccessGroupID; } /** * Name of the volume access group. **/ public String getName() { return this.name; } /** * List of unique initiator names belonging to the volume access group. **/ public String[] getInitiators() { return this.initiators; } /** * List of volumes belonging to the volume access group. **/ public Long[] getVolumes() { return this.volumes; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; VolumeAccessGroup that = (VolumeAccessGroup) o; return Objects.equals( volumeAccessGroupID , that.volumeAccessGroupID ) && Objects.equals( name , that.name ) && Objects.deepEquals( initiators , that.initiators ) && Objects.deepEquals( volumes , that.volumes ); } @Override public int hashCode() { return Objects.hash( volumeAccessGroupID, name, initiators, volumes ); } @Override public String toString() { final StringBuilder sb = new StringBuilder(); sb.append( "{ " ); sb.append(" volumeAccessGroupID : ").append(volumeAccessGroupID).append(","); sb.append(" name : ").append(name).append(","); sb.append(" initiators : ").append(Arrays.toString(initiators)).append(","); sb.append(" volumes : ").append(Arrays.toString(volumes)); 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 volumeAccessGroupID; private String name; private String[] initiators; private Long[] volumes; private Builder() { } public VolumeAccessGroup build() { return new VolumeAccessGroup ( this.volumeAccessGroupID, this.name, this.initiators, this.volumes ); } private VolumeAccessGroup.Builder buildFrom(final VolumeAccessGroup req) { this.volumeAccessGroupID = req.volumeAccessGroupID; this.name = req.name; this.initiators = req.initiators; this.volumes = req.volumes; return this; } public VolumeAccessGroup.Builder volumeAccessGroupID(final Long volumeAccessGroupID) { this.volumeAccessGroupID = volumeAccessGroupID; return this; } public VolumeAccessGroup.Builder name(final String name) { this.name = name; return this; } public VolumeAccessGroup.Builder initiators(final String[] initiators) { this.initiators = initiators; return this; } public VolumeAccessGroup.Builder volumes(final Long[] volumes) { this.volumes = volumes; return this; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy