/*
* Copyright (c) 2015 EMC Corporation
* All Rights Reserved
*/
package com.emc.storageos.computesystemcontroller.impl;
import java.net.URI;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.emc.storageos.db.client.DbClient;
import com.emc.storageos.db.client.model.Operation.Status;
import com.emc.storageos.db.client.model.VcenterDataCenter;
import com.emc.storageos.exceptions.DeviceControllerException;
import com.emc.storageos.svcs.errorhandling.model.ServiceCoded;
public class VcenterDataCenterCompleter extends ComputeSystemCompleter {
private static final Logger _logger = LoggerFactory.getLogger(VcenterDataCenterCompleter.class);
public VcenterDataCenterCompleter(URI id, boolean deactivateOnComplete, String opId) {
super(VcenterDataCenter.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(VcenterDataCenter.class, this.getId(), getOpId(), coded);
break;
default:
dbClient.ready(VcenterDataCenter.class, this.getId(), getOpId());
}
if (deactivateOnComplete && status.equals(Status.ready)) {
VcenterDataCenter datacenter = dbClient.queryObject(VcenterDataCenter.class, this.getId());
if (datacenter != null && !datacenter.getInactive()) {
ComputeSystemHelper.doDeactivateVcenterDataCenter(dbClient, datacenter);
_logger.info("Deactivating datacenter: " + this.getId());
}
}
}
}