/***************************************************************************
* Copyright (c) 2012-2015 VMware, 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.
***************************************************************************/
package com.vmware.bdd.dal.impl;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.List;
import java.util.Set;
import org.apache.log4j.Logger;
import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.criterion.Criterion;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import com.vmware.bdd.apitypes.ClusterStatus;
import com.vmware.bdd.dal.IClusterDAO;
import com.vmware.bdd.entity.ClusterEntity;
import com.vmware.bdd.entity.NodeEntity;
import com.vmware.bdd.entity.NodeGroupEntity;
import com.vmware.bdd.entity.VcResourcePoolEntity;
import com.vmware.bdd.utils.AuAssert;
import com.vmware.bdd.utils.CommonUtil;
/**
* @author Terry Li
* @since 0.8
* @version 0.8
*
*/
@Repository
@Transactional(readOnly = true)
public class ClusterDAO extends BaseDAO<ClusterEntity> implements IClusterDAO {
private final static Logger logger = Logger.getLogger(ClusterDAO.class);
@Override
public ClusterEntity findByName(String name) {
return findUniqueByCriteria(Restrictions.eq("name", name).ignoreCase());
}
@Override
@SuppressWarnings("unchecked")
public List<String> findAllClusterNames() {
logger.debug("findAllClusterNames");
List<String> clusterNames =
this.sessionFactory.getCurrentSession().createQuery(
"select distinct c.name from ClusterEntity c").list();
return clusterNames;
}
@Override
public ClusterEntity findWithNodeGroups(String clusterName) {
logger.debug("findWithNodeGroups using named query:"+clusterName);
return (ClusterEntity)this.sessionFactory.getCurrentSession()
.getNamedQuery("cluster.findClusterWithNgs")
.setString("clusterName", clusterName)
.uniqueResult();
}
@Override
public ClusterEntity findWithNodes(String clusterName, boolean includeVolumes) {
logger.debug("findWithNodes using named query:"+clusterName);
return (ClusterEntity)this.sessionFactory.getCurrentSession()
.getNamedQuery(includeVolumes ? "cluster.findClusterWithVolumes" : "cluster.findClusterWithNodes")
.setString("clusterName", clusterName)
.uniqueResult();
}
@Override
public List<String> findClustersByUsedResourcePool(String rpName) {
List<String> clusterNames = new ArrayList<String>();
// query cluster entities to check if resource pool is used by them.
List<ClusterEntity> clusters = findAll();
for (ClusterEntity cluster : clusters) {
Set<VcResourcePoolEntity> usedRps = cluster.getUsedRps();
for (VcResourcePoolEntity vcRp : usedRps) {
if (rpName.equals(vcRp.getName())) {
clusterNames.add(cluster.getName());
break;
}
}
}
return clusterNames;
}
@Override
public List<String> findClustersByUsedDatastores(Set<String> patterns) {
List<String> clusterNames = new ArrayList<String>();
// query cluster entities to check if the datastore is used by them.
List<ClusterEntity> clusters = findAll();
for (ClusterEntity cluster : clusters) {
Set<String> usedDS = cluster.getUsedVcDatastores();
if (CommonUtil.matchDatastorePattern(patterns, usedDS)) {
clusterNames.add(cluster.getName());
}
}
return clusterNames;
}
@Override
public List<String> findClustersByAppManager(String appManagerName) {
Order order = Order.asc("name");
List<ClusterEntity> clusters =
findByCriteria(new Order[] { order }, null, null,
Restrictions.eq("appmanager", appManagerName));
List<String> clusterNames = new ArrayList<String>();
for (ClusterEntity cluster : clusters) {
clusterNames.add(cluster.getName());
}
return clusterNames;
}
@Override
public boolean isExist(String name) {
if (findByName(name) == null)
return true;
return false;
}
@Override
@Transactional
public void updateStatus(String name, ClusterStatus status) {
ClusterEntity cluster = findByName(name);
AuAssert.check(cluster != null);
cluster.setStatus(status);
}
@Override
public List<NodeEntity> getAllNodes(String name) {
List<NodeEntity> nodes = new ArrayList<NodeEntity>();
ClusterEntity cluster = findByName(name);
for (NodeGroupEntity group : cluster.getNodeGroups()) {
nodes.addAll(group.getNodes());
}
return nodes;
}
@Override
@Transactional
public ClusterStatus getStatus(String clusterName) {
ClusterEntity cluster = findByName(clusterName);
AuAssert.check(cluster != null);
return cluster.getStatus();
}
@Override
@Transactional
public void updateLastStatus(String clusterName, ClusterStatus status) {
ClusterEntity cluster = findByName(clusterName);
AuAssert.check(cluster != null);
cluster.setLastStatus(status);
}
@Override
public String findInfraConfig(String clusterName) {
Session session = getSessionFactory().getCurrentSession();
Criteria criteria = session.createCriteria(ClusterEntity.class);
criteria.add(Restrictions.eq("name", clusterName));
criteria.setProjection(Projections.property("infraConfig"));
return (String) criteria.uniqueResult();
}
@Override
public List<String> findClusterByStatus(ClusterStatus status) {
List<String> clusterNames = new ArrayList<String>();
List<ClusterEntity> clusterList = findByCriteria(Restrictions.eq("status", status));
if (clusterList != null) {
for (ClusterEntity cluster : clusterList) {
clusterNames.add(cluster.getName());
}
}
return clusterNames;
}
@Override
public List<String> findClusterByStatus(EnumSet<ClusterStatus> statusSet) {
List<String> clusterNames = new ArrayList<String>();
if (statusSet != null && statusSet.size() > 0) {
List<Criterion> criterionList = new ArrayList<Criterion>();
for (ClusterStatus status : statusSet) {
criterionList.add(Restrictions.eq("status", status));
}
Criterion finalCriterion = Restrictions.or(criterionList.toArray(new Criterion[criterionList.size()]));
List<ClusterEntity> clusterList = findByCriteria(finalCriterion);
if (clusterList != null) {
for (ClusterEntity cluster : clusterList) {
clusterNames.add(cluster.getName());
}
}
}
return clusterNames;
}
}