/*
* Copyright (c) 2015 EMC Corporation
* All Rights Reserved
*/
package com.emc.storageos.computesystemcontroller.impl;
import java.net.URI;
import java.util.List;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.emc.storageos.db.client.DbClient;
import com.emc.storageos.db.client.constraint.NamedElementQueryResultList;
import com.emc.storageos.db.client.model.VcenterDataCenter;
import com.emc.storageos.db.client.model.DiscoveredDataObject.RegistrationStatus;
import com.emc.storageos.db.client.model.Operation.Status;
import com.emc.storageos.db.client.model.Vcenter;
import com.emc.storageos.exceptions.DeviceControllerException;
import com.emc.storageos.svcs.errorhandling.model.ServiceCoded;
public class VcenterCompleter extends ComputeSystemCompleter {
private static final Logger _logger = LoggerFactory
.getLogger(VcenterCompleter.class);
public VcenterCompleter(URI id, boolean deactivateOnComplete, String opId) {
super(Vcenter.class, id, deactivateOnComplete, opId);
}
@Override
protected void complete(DbClient dbClient, Status status, ServiceCoded coded) throws DeviceControllerException {
super.complete(dbClient, status, coded);
switch (status) {
case error:
dbClient.error(Vcenter.class, this.getId(), getOpId(), coded);
break;
default:
dbClient.ready(Vcenter.class, this.getId(), getOpId());
}
if (deactivateOnComplete && status.equals(Status.ready)) {
Vcenter vcenter = dbClient.queryObject(Vcenter.class, this.getId());
List<NamedElementQueryResultList.NamedElement> datacenterUris = ComputeSystemHelper.listChildren(dbClient, vcenter.getId(),
VcenterDataCenter.class, "label", "vcenter");
for (NamedElementQueryResultList.NamedElement datacenterUri : datacenterUris) {
VcenterDataCenter dataCenter = dbClient.queryObject(VcenterDataCenter.class, datacenterUri.getId());
if (dataCenter != null && !dataCenter.getInactive()) {
ComputeSystemHelper.doDeactivateVcenterDataCenter(dbClient, dataCenter);
}
}
vcenter.setRegistrationStatus(RegistrationStatus.UNREGISTERED.toString());
dbClient.markForDeletion(vcenter);
_logger.info("Deactivating Vcenter: " + this.getId());
}
}
}