/************************************************************************** * AddC2KObject * * $Workfile$ * $Revision: 1.31 $ * $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.common.InvalidDataException; import com.c2kernel.entity.C2KLocalObject; import com.c2kernel.lookup.AgentPath; import com.c2kernel.lookup.ItemPath; import com.c2kernel.process.Gateway; import com.c2kernel.utils.Logger; /************************************************************************** * * @author $Author: abranson $ $Date: 2004/10/21 08:02:19 $ * @version $Revision: 1.31 $ **************************************************************************/ public class AddC2KObject extends PredefinedStep { /************************************************************************** * Constructor for Castror **************************************************************************/ public AddC2KObject() { super(); getProperties().put("Agent Role", "Admin"); } //requestdata is xmlstring @Override protected String runActivityLogic(AgentPath agent, ItemPath item, int transitionID, String requestData) throws InvalidDataException { String[] params = getDataList(requestData); if (Logger.doLog(3)) Logger.msg(3, "AddC2KObject: called by "+agent+" on "+item+" with parameters "+Arrays.toString(params)); try { C2KLocalObject obj = (C2KLocalObject)Gateway.getMarshaller().unmarshall(params[0]); Gateway.getStorage().put(item, obj, null ); return requestData; } catch( Exception ex ) { throw unknownException(ex); } } }