package org.opennaas.extensions.powernet.repository;
import java.util.ArrayList;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.opennaas.core.resources.IModel;
import org.opennaas.core.resources.IResourceBootstrapper;
import org.opennaas.core.resources.Resource;
import org.opennaas.core.resources.ResourceException;
import org.opennaas.extensions.gim.model.core.entities.PowerConsumer;
import org.opennaas.extensions.gim.model.core.entities.PowerDelivery;
import org.opennaas.extensions.gim.model.core.entities.PowerSupply;
import org.opennaas.extensions.powernet.model.PowerNetModel;
/**
*
* @author Isart Canyameres Gimenez (i2cat Foundation)
*
*/
public class PowerNetResourceBootstrapper implements IResourceBootstrapper {
Log log = LogFactory.getLog(PowerNetResourceBootstrapper.class);
private IModel oldModel;
@Override
public void bootstrap(Resource resource) throws ResourceException {
log.info("Loading bootstrap to start resource...");
oldModel = resource.getModel();
// Add here all the necessary methods to populate resource model
resetModel(resource);
}
@Override
public void resetModel(Resource resource) throws ResourceException {
PowerNetModel model = new PowerNetModel();
model.setId(resource.getResourceIdentifier().getId());
model.setConsumers(new ArrayList<PowerConsumer>());
model.setDeliveries(new ArrayList<PowerDelivery>());
model.setSupplies(new ArrayList<PowerSupply>());
resource.setModel(model);
}
@Override
public void revertBootstrap(Resource resource) throws ResourceException {
resource.setModel(oldModel);
}
}