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

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

package org.openstack4j.openstack.sahara.domain;

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

import org.openstack4j.model.sahara.ClusterTemplate;
import org.openstack4j.model.sahara.NodeGroup;
import org.openstack4j.model.sahara.ServiceConfig;
import org.openstack4j.model.sahara.builder.ClusterTemplateBuilder;
import org.openstack4j.openstack.common.ListResult;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonRootName;
import com.google.common.base.Objects;
import com.google.common.collect.Lists;

/**
 * An OpenStack Sahara
 * 
 * @author Ekasit Kijsipongse
 */
@JsonRootName("cluster_template")
public class SaharaClusterTemplate implements ClusterTemplate {

	private static final long serialVersionUID = 1L;
	
	@JsonProperty("hadoop_version")
	private String hadoopVersion;
	@JsonProperty("default_image_id")
	private String defaultImageId;
	private String name;
	@JsonProperty("updated_at")
        @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
        private Date updatedAt;
	@JsonProperty("tenant_id")
	private String tenantId;
	@JsonProperty("plugin_name")
	private String pluginName;
        @JsonProperty("anti_affinity")
        private List antiAffinity;
	private String description;
	private String id;
        @JsonProperty("node_groups")
        private List nodeGroups;
        @JsonProperty("neutron_management_network")
	private String managementNetworkId;
	@JsonProperty("created_at")
        @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
        private Date createdAt;
	@JsonProperty("cluster_configs")
	private Map clusterConfigs;

	/**
	 * {@inheritDoc}
	 */
	@Override
	public ClusterTemplateBuilder toBuilder() {
		return new ConcreteClusterTemplateBuilder(this);
	}

	/**
	 * @return the cluster template Builder
	 */
	public static ClusterTemplateBuilder builder() {
		return new ConcreteClusterTemplateBuilder();
	}
	
	/**
	 * {@inheritDoc}
	 */
	@Override
	public String getHadoopVersion() {
		return hadoopVersion;
	}

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

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

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

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

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

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

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

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

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

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

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

	/**
	 * {@inheritDoc}
	 */
	@Override
	public Map getClusterConfigs() {
		return clusterConfigs;
	}
	
	/**
	 * {@inheritDoc}
	 */
	@Override
	public String toString() {
		return Objects.toStringHelper(this).omitNullValues()
	             .add("id", id)
                     .add("name", name)
                     .add("description", description)
                     .add("hadoop_version", hadoopVersion)
                     .add("tenant_id",tenantId)
                     .add("created_at",createdAt)
                     .add("updated_at",updatedAt)
                     .add("plugin_name",pluginName)
                     .add("default_image_id", defaultImageId)
                     .add("anti_affinity",antiAffinity)
                     .add("neutron_management_network_id",managementNetworkId)
                     .add("node_groups",nodeGroups)
                     .add("cluster_configs",clusterConfigs)
                     .toString();
	}
	
	public static class ClusterTemplates extends ListResult {

		private static final long serialVersionUID = 1L;
		
                @JsonProperty("cluster_templates")
		private List nodeGroupTemplates;
		
		@Override
		protected List value() {
			return nodeGroupTemplates;
		}
	}
	
	public static class ConcreteClusterTemplateBuilder implements ClusterTemplateBuilder {

		private SaharaClusterTemplate m;
		
		ConcreteClusterTemplateBuilder() {
			this(new SaharaClusterTemplate());
		}
		
		ConcreteClusterTemplateBuilder(SaharaClusterTemplate m) {
			this.m = m;
		}

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

		@Override
		public ClusterTemplateBuilder from(ClusterTemplate in) {
			m = (SaharaClusterTemplate) in;
			return this;
                }
		
		@Override
		public ClusterTemplateBuilder pluginName(String pluginName) {
			m.pluginName = pluginName;
			return this;
		}

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


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

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

		@Override
		public ClusterTemplateBuilder description(String description) {
			m.description = description;
			return this;
		}

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

		@Override
                public ClusterTemplateBuilder 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;
                }

	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy