package io.cattle.platform.process.instance;
import io.cattle.platform.core.constants.StoragePoolConstants;
import io.cattle.platform.core.constants.VolumeConstants;
import io.cattle.platform.core.dao.StoragePoolDao;
import io.cattle.platform.core.model.StoragePool;
import io.cattle.platform.core.model.Volume;
import io.cattle.platform.engine.handler.HandlerResult;
import io.cattle.platform.engine.handler.ProcessPreListener;
import io.cattle.platform.engine.process.ProcessInstance;
import io.cattle.platform.engine.process.ProcessState;
import io.cattle.platform.object.meta.ObjectMetaDataManager;
import io.cattle.platform.object.util.DataAccessor;
import io.cattle.platform.process.common.handler.AbstractObjectProcessLogic;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.inject.Inject;
import javax.inject.Named;
import org.apache.commons.lang3.StringUtils;
@Named
public class VolumePreCreate extends AbstractObjectProcessLogic implements ProcessPreListener {
@Inject
StoragePoolDao storagePoolDao;
@Override
public String[] getProcessNames() {
return new String[] { "volume.create" };
}
@Override
public HandlerResult handle(ProcessState state, ProcessInstance process) {
Volume v = (Volume)state.getResource();
String driver = DataAccessor.fieldString(v, VolumeConstants.FIELD_VOLUME_DRIVER);
if (StringUtils.isEmpty(driver) || VolumeConstants.LOCAL_DRIVER.equals(driver)) {
return null;
}
List<? extends StoragePool> pools = storagePoolDao.findStoragePoolByDriverName(v.getAccountId(), driver);
if (pools.size() == 0) {
return null;
}
StoragePool sp = pools.get(0);
Map<String, Object> data = new HashMap<>();
List<String> volumeCap = DataAccessor.fieldStringList(sp, StoragePoolConstants.FIELD_VOLUME_CAPABILITIES);
if (volumeCap != null && volumeCap.size() > 0) {
data.put(ObjectMetaDataManager.CAPABILITIES_FIELD, volumeCap);
}
return new HandlerResult(data);
}
}