use of com.emc.storageos.plugins.BaseCollectionException in project coprhd-controller by CoprHD.
the class ProtocolEndPointToPortProcessor method processResult.
@Override
public void processResult(Operation operation, Object resultObj, Map<String, Object> keyMap) throws BaseCollectionException {
try {
@SuppressWarnings("unchecked") final Iterator<CIMInstance> it = (Iterator<CIMInstance>) resultObj;
CIMObjectPath protocolEndPointPath = getObjectPathfromCIMArgument(args);
AccessProfile profile = (AccessProfile) keyMap.get(Constants.ACCESSPROFILE);
_dbClient = (DbClient) keyMap.get(Constants.dbClient);
StorageSystem device = _dbClient.queryObject(StorageSystem.class, profile.getSystemId());
String protocolEndPointId = protocolEndPointPath.getKey(Constants.NAME).getValue().toString();
_log.info("Protocol End Point ID :" + protocolEndPointId);
@SuppressWarnings("unchecked") Map<String, URI> volumeToRAGroupMap = (Map<String, URI>) keyMap.get(Constants.RAGROUP);
URI remoteRAGroupUri = volumeToRAGroupMap.get(protocolEndPointId);
_log.info("Remote RA Group URI :" + remoteRAGroupUri);
String sourceSystemSerialId = keyMap.get(Constants._serialID).toString();
_log.info("Source Serial ID :" + sourceSystemSerialId);
RemoteDirectorGroup remoteGroup = _dbClient.queryObject(RemoteDirectorGroup.class, remoteRAGroupUri);
if (remoteGroup == null) {
_log.info("RA Group Not Found {}", remoteRAGroupUri);
}
while (it.hasNext()) {
CIMInstance portInstance = it.next();
StoragePort port = checkStoragePortExistsInDB(portInstance, device, _dbClient);
if (null == port) {
_log.info("RA Group Port Not Found {}", portInstance.getObjectPath());
continue;
}
if (portInstance.getObjectPath().toString().contains(sourceSystemSerialId)) {
remoteGroup.setSourcePort(port.getId());
_log.info("Source Port added :" + portInstance.getObjectPath());
} else {
remoteGroup.setRemotePort(port.getId());
_log.info("Remote Port added :" + portInstance.getObjectPath());
}
_dbClient.persistObject(remoteGroup);
}
} catch (Exception e) {
_log.error("Discovering Ports for RA Groups failed", e);
}
}
use of com.emc.storageos.plugins.BaseCollectionException in project coprhd-controller by CoprHD.
the class RemoteConnectivityCollectionProcessor method processResult.
@Override
public void processResult(Operation operation, Object resultObj, Map<String, Object> keyMap) throws BaseCollectionException {
StorageSystem device = null;
try {
_dbClient = (DbClient) keyMap.get(Constants.dbClient);
AccessProfile profile = (AccessProfile) keyMap.get(Constants.ACCESSPROFILE);
device = getStorageSystem(_dbClient, profile.getSystemId());
@SuppressWarnings("unchecked") Iterator<CIMInstance> iterator = (Iterator<CIMInstance>) resultObj;
Set<String> remoteConnectedStorageSystems = new HashSet<String>();
boolean srdfSupported = false;
while (iterator.hasNext()) {
srdfSupported = true;
CIMInstance instance = iterator.next();
RemoteDirectorGroup remoteRAGroup = checkRAGroupExistsInDB(_dbClient, instance);
remoteRAGroup = createRAGroup(instance, remoteRAGroup, device);
raGroupIds.add(remoteRAGroup.getNativeGuid());
addRemoteConnectedStorageSystems(instance, device, remoteConnectedStorageSystems);
addPath(keyMap, operation.getResult(), instance.getObjectPath());
}
updateSupportedCopyModes(srdfSupported, device);
updateRemoteConnectedStorageSystems(device, remoteConnectedStorageSystems);
_dbClient.persistObject(device);
if (!newlyAddedGroups.isEmpty()) {
_dbClient.createObject(newlyAddedGroups);
}
if (!modifiedGroups.isEmpty()) {
_dbClient.persistObject(modifiedGroups);
}
performRAGroupsBookKeeping(raGroupIds, device.getId());
} catch (Exception e) {
_log.error("Finding out Active RA Groups Failed.SRDF will not be supported on this Array {} ", device.getNativeGuid(), e);
} finally {
raGroupIds = null;
newlyAddedGroups = null;
modifiedGroups = null;
}
}
use of com.emc.storageos.plugins.BaseCollectionException in project coprhd-controller by CoprHD.
the class SRDFStorageSyncProcessor method processResult.
@Override
public void processResult(Operation operation, Object resultObj, Map<String, Object> keyMap) throws BaseCollectionException {
CloseableIterator<CIMObjectPath> synchronizedInstancePaths = null;
EnumerateResponse<CIMObjectPath> synchronizedInstancePathChunks = null;
WBEMClient client = SMICommunicationInterface.getCIMClient(keyMap);
try {
synchronizedInstancePathChunks = (EnumerateResponse<CIMObjectPath>) resultObj;
synchronizedInstancePaths = synchronizedInstancePathChunks.getResponses();
processStorageSynchronizedPaths(operation, synchronizedInstancePaths, resultObj, keyMap);
while (!synchronizedInstancePathChunks.isEnd()) {
synchronizedInstancePathChunks = client.getInstancePaths(Constants.SYNC_PATH, synchronizedInstancePathChunks.getContext(), Constants.SYNC_BATCH_SIZE);
processStorageSynchronizedPaths(operation, synchronizedInstancePathChunks.getResponses(), resultObj, keyMap);
}
}//
catch (Exception e) {
_log.error("Processing Storage Synchronized Realtions for SRDF failed : ", e);
} finally {
if (null != synchronizedInstancePaths) {
synchronizedInstancePaths.close();
}
if (null != synchronizedInstancePathChunks) {
try {
client.closeEnumeration(Constants.SYNC_PATH, synchronizedInstancePathChunks.getContext());
} catch (Exception e) {
_log.debug("Exception occurred while closing enumeration", e);
}
}
}
resultObj = null;
}
use of com.emc.storageos.plugins.BaseCollectionException in project coprhd-controller by CoprHD.
the class VolumeToSynchronizedRefProcessor method processResult.
@Override
public void processResult(Operation operation, Object resultObj, Map<String, Object> keyMap) throws BaseCollectionException {
try {
@SuppressWarnings("unchecked") final Iterator<CIMInstance> it = (Iterator<CIMInstance>) resultObj;
CIMObjectPath volumePath = getObjectPathfromCIMArgument(args);
String volumeNativeGuid = getVolumeNativeGuid(volumePath);
_dbClient = (DbClient) keyMap.get(Constants.dbClient);
@SuppressWarnings("unchecked") Map<String, URI> volumeToRAGroupMap = (Map<String, URI>) keyMap.get(Constants.RAGROUP);
URI remoteRAGroupUri = volumeToRAGroupMap.get(volumeNativeGuid);
_log.debug("Remote RA Group URI {}", remoteRAGroupUri);
RemoteDirectorGroup remoteGroup = _dbClient.queryObject(RemoteDirectorGroup.class, remoteRAGroupUri);
if (null == remoteGroup) {
_log.info("Remote Group not found {}", remoteRAGroupUri);
return;
}
String copyMode = null;
int numberOfTargets = 0;
if (it != null) {
while (it.hasNext()) {
CIMInstance storageSynchronized = it.next();
CIMObjectPath storageSynchronizedPath = storageSynchronized.getObjectPath();
CIMObjectPath sourcePath = (CIMObjectPath) storageSynchronizedPath.getKey(Constants._SystemElement).getValue();
CIMObjectPath destPath = (CIMObjectPath) storageSynchronizedPath.getKey(Constants._SyncedElement).getValue();
String sourceNativeGuid = createKeyfromPath(sourcePath);
String targetNativeGuid = createKeyfromPath(destPath);
_log.info("Source : {} , target : {}", sourceNativeGuid, targetNativeGuid);
if (!findVolumesArefromSameArray(sourceNativeGuid, targetNativeGuid)) {
numberOfTargets++;
copyMode = storageSynchronized.getPropertyValue(MODE).toString();
_log.info("RDF Group {} detected Copy Mode {}", remoteGroup.getNativeGuid(), copyMode);
}
}
}
if (numberOfTargets > 1) {
_log.info("RA Group {} is associated with Cascaded SRDF configuration, hence copyMode will not be updated.", remoteGroup.getNativeGuid());
remoteGroup.setSupported(false);
} else {
// set copy Mode on Remote Group.
// get Volume-->RA Group Mapping
// if Copy Mode is already set on ViPr remoteGroup in DB, then don't change it.
remoteGroup.setSupported(true);
if (updateSupportedCopyMode(remoteGroup.getSupportedCopyMode())) {
// in general, this property value can't be null, but in customer case we are seeing this, hence added this check
if (null == copyMode) {
remoteGroup.setSupportedCopyMode(SupportedCopyModes.UNKNOWN.toString());
} else {
remoteGroup.setSupportedCopyMode(SupportedCopyModes.getCopyMode(copyMode));
}
}
_log.debug("Remote Group Copy Mode: {}", remoteGroup.getSupportedCopyMode());
}
_dbClient.persistObject(remoteGroup);
} catch (Exception e) {
_log.error("Copy Mode Discovery failed for remote Groups ", e);
}
}
use of com.emc.storageos.plugins.BaseCollectionException in project coprhd-controller by CoprHD.
the class ScannerProcessor method processResult.
/**
* {@inheritDoc}
*/
@Override
public void processResult(Operation operation, Object resultObj, Map<String, Object> keyMap) throws BaseCollectionException {
AccessProfile profile = null;
try {
profile = (AccessProfile) keyMap.get(Constants.ACCESSPROFILE);
@SuppressWarnings("unchecked") final Iterator<CIMInstance> it = (Iterator<CIMInstance>) resultObj;
while (it.hasNext()) {
try {
final CIMInstance instance = it.next();
final CIMObjectPath path = instance.getObjectPath();
if (isIBMInstance(instance) || path.toString().toLowerCase().contains(Constants.CLARIION) || !isRemoteSystem(instance)) {
addPath(keyMap, operation.getResult(), path);
} else {
_logger.info("Skipping Detection of Remote System {}", instance.getPropertyValue(Constants.NAME));
}
} catch (Exception e) {
_logger.error("Scanner Failed to scan Provider : {}-->{}", profile.getserialID(), getMessage(e));
}
}
} catch (Exception e) {
_logger.error("Scanner Failed to scan Provider : {}-->{}", profile.getIpAddress(), getMessage(e));
}
}
Aggregations