package com.c2kernel.lifecycle.instance.predefined.server; import java.util.Stack; import com.c2kernel.common.CannotManageException; import com.c2kernel.common.InvalidDataException; import com.c2kernel.common.ObjectAlreadyExistsException; import com.c2kernel.common.ObjectCannotBeUpdated; import com.c2kernel.lifecycle.instance.predefined.PredefinedStep; import com.c2kernel.lookup.AgentPath; import com.c2kernel.lookup.DomainPath; import com.c2kernel.process.Gateway; import com.c2kernel.utils.Logger; public class AddDomainContext extends PredefinedStep { public AddDomainContext() { super(); } @Override protected String runActivityLogic(AgentPath agent, int itemSysKey, int transitionID, String requestData) throws InvalidDataException { Logger.msg(1, "AddDomainContext::request() - Starting."); DomainPath pathToAdd = new DomainPath(getDataList(requestData)[0]); if (pathToAdd.exists()) throw new InvalidDataException("Context "+pathToAdd+" already exists", ""); // collect parent paths if they don't exist Stack pathsToAdd = new Stack(); while(pathToAdd!= null && !pathToAdd.exists()) { pathsToAdd.push(pathToAdd); pathToAdd = pathToAdd.getParent(); } while(!pathsToAdd.empty()) { pathToAdd = pathsToAdd.pop(); try { Gateway.getLookupManager().add(pathToAdd); } catch (ObjectAlreadyExistsException e) { Logger.error("Context "+pathToAdd+" inconsistently exists."); } catch (ObjectCannotBeUpdated e) { Logger.error(e); throw new InvalidDataException("Exception adding path "+pathToAdd+": "+e.getMessage(), ""); } catch (CannotManageException e) { throw new InvalidDataException("Cannot alter directory in a non-server process", ""); } } return requestData; } }