/************************************************************************** * AssignItemToSlot * * $Workfile$ * $Revision: 1.8 $ * $Date: 2004/10/21 08:02:19 $ * * Copyright (C) 2001 CERN - European Organization for Nuclear Research * All rights reserved. **************************************************************************/ package com.c2kernel.lifecycle.instance.predefined; import java.util.Arrays; import com.c2kernel.collection.Aggregation; import com.c2kernel.collection.AggregationMember; import com.c2kernel.collection.MembershipException; import com.c2kernel.common.InvalidDataException; import com.c2kernel.common.ObjectNotFoundException; import com.c2kernel.entity.C2KLocalObject; import com.c2kernel.lookup.AgentPath; import com.c2kernel.lookup.ItemPath; import com.c2kernel.persistency.ClusterStorage; import com.c2kernel.persistency.ClusterStorageException; import com.c2kernel.process.Gateway; import com.c2kernel.utils.Logger; /************************************************************************** * * @author $Author: abranson $ $Date: 2004/10/21 08:02:19 $ * @version $Revision: 1.8 $ **************************************************************************/ public class AssignItemToSlot extends PredefinedStep { /************************************************************************** * Constructor for Castor **************************************************************************/ public AssignItemToSlot() { super(); } /** * Params: * 0 - collection name * 1 - slot number * 2 - target entity key */ @Override protected String runActivityLogic(AgentPath agent, ItemPath item, int transitionID, String requestData) throws InvalidDataException { String collName; int slotNo; ItemPath childItem; Aggregation agg; // extract parameters String[] params = getDataList(requestData); if (Logger.doLog(3)) Logger.msg(3, "AssignItemToSlot: called by "+agent+" on "+item+" with parameters "+Arrays.toString(params)); try { collName = params[0]; slotNo = Integer.parseInt(params[1]); childItem = ItemPath.fromUUIDString(params[2]); } catch (Exception e) { throw new InvalidDataException("AssignItemToSlot: Invalid parameters "+Arrays.toString(params), ""); } // load collection C2KLocalObject collObj; try { collObj = Gateway.getStorage().get(item, ClusterStorage.COLLECTION+"/"+collName, null); } catch (ObjectNotFoundException ex) { throw new InvalidDataException("AssignItemToSlot: Collection '"+collName+"' not found in this Item", ""); } catch (ClusterStorageException ex) { Logger.error(ex); throw new InvalidDataException("AssignItemToSlot: Error loading collection '\"+collName+\"': "+ex.getMessage(), ""); } if (!(collObj instanceof Aggregation)) throw new InvalidDataException("AssignItemToSlot: AssignItemToSlot operates on Aggregation collections only.", ""); agg = (Aggregation)collObj; // find member and assign entity boolean stored = false; for (AggregationMember member : agg.getMembers().list) { if (member.getID() == slotNo) { if (member.getItemPath() != null) throw new InvalidDataException("AssignItemToSlot: Member slot "+slotNo+" not empty", ""); try { member.assignItem(childItem); } catch (MembershipException e) { throw new InvalidDataException("AssignItemToSlot: Item "+childItem+" does not fit in slot "+slotNo, ""); } stored = true; break; } } if (!stored) { throw new InvalidDataException("AssignItemToSlot: Member slot "+slotNo+" not found.", ""); } try { Gateway.getStorage().put(item, agg, null); } catch (ClusterStorageException e) { unknownException(e); } return requestData; } }