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

org.openstack4j.openstack.sahara.domain.SaharaCluster Maven / Gradle / Ivy

There is a newer version: 3.12
Show newest version
package org.openstack4j.openstack.sahara.domain;

import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonRootName;
import com.google.common.base.MoreObjects;
import com.google.common.collect.Lists;
import org.openstack4j.model.compute.Image;
import org.openstack4j.model.sahara.Cluster;
import org.openstack4j.model.sahara.NodeGroup;
import org.openstack4j.model.sahara.ServiceConfig;
import org.openstack4j.model.sahara.ServiceInfo;
import org.openstack4j.model.sahara.builder.ClusterBuilder;
import org.openstack4j.openstack.common.ListResult;

/**
 * For mapping JSON response to/from java objects
 *
 * @author [email protected]
 */

@JsonRootName("cluster")
@JsonIgnoreProperties(ignoreUnknown = true)
public class SaharaCluster implements Cluster {

    private static final long serialVersionUID = 1L;

    private Status status;
    @JsonProperty("info")
    private Map infos;
    @JsonProperty("cluster_template_id")
    private String clusterTemplateId;
    @JsonProperty("is_transient")
    private Boolean isTransient;
    private String description;
    @JsonProperty("cluster_configs")
    private Map clusterConfigs;
    @JsonProperty("created_at")
    @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
    private Date createdAt;
    @JsonProperty("default_image_id")
    private String defaultImageId;
    @JsonProperty("user_keypair_id")
    private String userKeypairId;
    @JsonProperty("updated_at")
    @JsonFormat(pattern = "yyyy-MM-dd'T'HH:mm:ss")
    private Date updatedAt;
    @JsonProperty("plugin_name")
    private String pluginName;
    @JsonProperty("neutron_management_network")
    private String managementNetworkId;
    @JsonProperty("anti_affinity")
    private List antiAffinity;
    @JsonProperty("tenant_id")
    private String tenantId;
    @JsonProperty("node_groups")
    private List nodeGroups;
    @JsonProperty("management_public_key")
    private String managementPublicKey;
    @JsonProperty("status_description")
    private String statusDescription;
    @JsonProperty("hadoop_version")
    private String hadoopVersion;
    private String id;
    @JsonProperty("trust_id")
    private String trustId;    // TODO: What is trust_id?
    private String name;

    /**
     * @return the cluster Builder
     */
    public static ClusterBuilder builder() {
        return new ConcreteClusterBuilder();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Status getStatus() {
        return status;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Map getInfos() {
        return infos;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getClusterTemplateId() {
        return clusterTemplateId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Boolean isTransient() {
        return isTransient;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getDescription() {
        return description;
    }

    /**
     * {@inheritDoc}
     */
    public Map getClusterConfigs() {
        return clusterConfigs;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Date getCreatedAt() {
        return createdAt;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getDefaultImageId() {
        return defaultImageId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getUserKeypairId() {
        return userKeypairId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public Date getUpdatedAt() {
        return updatedAt;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getPluginName() {
        return pluginName;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getManagementNetworkId() {
        return managementNetworkId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List getAntiAffinity() {
        return antiAffinity;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getTenantId() {
        return tenantId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public List getNodeGroups() {
        return nodeGroups;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getManagementPublicKey() {
        return managementPublicKey;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getStatusDescription() {
        return statusDescription;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getHadoopVersion() {
        return hadoopVersion;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getId() {
        return id;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getTrustId() {
        return trustId;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public String getName() {
        return name;
    }

    @Override
    public String toString() {
        return MoreObjects.toStringHelper(this).omitNullValues()
                .add("id", id)
                .add("name", name)
                .add("description", description)
                .add("status", status)
                .add("created_at", createdAt)
                .add("updated_at", updatedAt)
                .add("tenant_id", tenantId)
                .add("cluster_template_id", clusterTemplateId)
                .add("is_transient", isTransient)
                .add("default_image_id", defaultImageId)
                .add("user_keypair_id", userKeypairId)
                .add("plugin_name", pluginName)
                .add("neutron_management_network", managementNetworkId)
                .add("cluster_configs", clusterConfigs)
                .add("anti_affinity", antiAffinity)
                .add("node_groups", nodeGroups)
                .add("management_public_key", managementPublicKey)
                .add("status_description", statusDescription)
                .add("hadoop_version", hadoopVersion)
                .add("trust_id", trustId)
                .add("info", infos)
                .toString();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public ClusterBuilder toBuilder() {
        return new ConcreteClusterBuilder(this);
    }

    public static class Clusters extends ListResult {

        private static final long serialVersionUID = 1L;

        @JsonProperty("clusters")
        private List clusters;

        public List value() {
            return clusters;
        }
    }

    public static class ConcreteClusterBuilder implements ClusterBuilder {

        SaharaCluster m;

        ConcreteClusterBuilder() {
            this(new SaharaCluster());
        }

        ConcreteClusterBuilder(SaharaCluster m) {
            this.m = m;
        }

        @Override
        public ClusterBuilder name(String name) {
            m.name = name;
            return this;
        }

        @Override
        public ClusterBuilder hadoopVersion(String hadoopVersion) {
            m.hadoopVersion = hadoopVersion;
            return this;
        }

        @Override
        public ClusterBuilder pluginName(String pluginName) {
            m.pluginName = pluginName;
            return this;
        }

        @Override
        public ClusterBuilder template(String clusterTemplateId) {
            m.clusterTemplateId = clusterTemplateId;
            return this;
        }

        @Override
        public ClusterBuilder image(String imageId) {
            m.defaultImageId = imageId;
            return this;
        }

        public ClusterBuilder image(Image image) {
            m.defaultImageId = image.getId();
            return this;
        }

        @Override
        public ClusterBuilder keypairName(String keypairName) {
            m.userKeypairId = keypairName;
            return this;
        }

        @Override
        public ClusterBuilder managementNetworkId(String networkId) {
            m.managementNetworkId = networkId;
            return this;
        }

        @Override
        public ClusterBuilder addNodeGroup(NodeGroup nodeGroup) {
            if (m.nodeGroups == null)
                m.nodeGroups = Lists.newArrayList();
            m.nodeGroups.add((SaharaNodeGroup) nodeGroup);
            return this;
        }

        @Override
        public ClusterBuilder addServiceConfig(String name, ServiceConfig config) {
            if (name != null && !name.isEmpty()) {
                if (m.clusterConfigs == null)
                    m.clusterConfigs = new HashMap();
                m.clusterConfigs.put(name, (SaharaServiceConfig) config);
            }
            return this;
        }

        @Override
        public Cluster build() {
            return m;
        }

        @Override
        public ClusterBuilder from(Cluster in) {
            m = (SaharaCluster) in;
            return this;
        }

    }


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy