summaryrefslogtreecommitdiff
path: root/src/main/java/com/c2kernel/lifecycle/instance/predefined/server/RemoveRole.java
blob: ec3071b489c48ca6e420381c8024a23a2f5c848f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/**************************************************************************
 * CreateNewAgent.java
 *
 * Copyright (C) 2001 CERN - European Organization for Nuclear Research
 * All rights reserved.
 **************************************************************************/

package com.c2kernel.lifecycle.instance.predefined.server;

import java.util.Arrays;

import com.c2kernel.common.CannotManageException;
import com.c2kernel.common.InvalidDataException;
import com.c2kernel.common.ObjectCannotBeUpdated;
import com.c2kernel.common.ObjectNotFoundException;
import com.c2kernel.lifecycle.instance.predefined.PredefinedStep;
import com.c2kernel.lookup.AgentPath;
import com.c2kernel.lookup.ItemPath;
import com.c2kernel.lookup.LookupManager;
import com.c2kernel.lookup.RolePath;
import com.c2kernel.process.Gateway;
import com.c2kernel.utils.Logger;

public class RemoveRole extends PredefinedStep
{
    public RemoveRole()
    {
        super();
    }

	//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));
    	LookupManager lookup;
		try {
			lookup = Gateway.getLookupManager();
		} catch (CannotManageException e) {
			throw new InvalidDataException(e.getMessage(), "");
		}
		
       	RolePath thisRole; AgentPath[] agents;
		try {
			thisRole = lookup.getRolePath(params[0]);
			agents = Gateway.getLookup().getAgents(thisRole);
		} catch (ObjectNotFoundException e) {
			throw new InvalidDataException("Role "+params[0]+" not found.", "");
		}
       	
       	if (agents.length > 0)
       		throw new InvalidDataException("Cannot remove role. "+agents.length+" agents still hold it.", "");
       	try {
			lookup.delete(thisRole);
		} catch (ObjectCannotBeUpdated e) {
			Logger.error(e);
			throw new InvalidDataException("Role "+params[0]+" could not be removed.", "");
		}

        return requestData;

    }
}