01: /*
02: * <copyright>
03: *
04: * Copyright 2000-2004 BBNT Solutions, LLC
05: * under sponsorship of the Defense Advanced Research Projects
06: * Agency (DARPA).
07: *
08: * You can redistribute this software and/or modify it under the
09: * terms of the Cougaar Open Source License as published on the
10: * Cougaar Open Source Website (www.cougaar.org).
11: *
12: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
13: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
14: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
15: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
16: * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
17: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
18: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19: * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20: * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
22: * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23: *
24: * </copyright>
25: */
26:
27: package org.cougaar.tools.csmart.experiment;
28:
29: import org.cougaar.tools.csmart.core.property.BaseComponent;
30:
31: /**
32: * The interface for adding and removing hosts from a society.
33: */
34: public interface HostComponent extends BaseComponent {
35:
36: /**
37: * Add a node to the host.
38: * @param node the node to add
39: */
40: NodeComponent addNode(NodeComponent node);
41:
42: /**
43: * Remove the specified node from the host.
44: * @param node the node to remove
45: */
46: void removeNode(NodeComponent node);
47:
48: /**
49: * Get the nodes in this host.
50: * @return array of node components
51: */
52: NodeComponent[] getNodes();
53:
54: /**
55: * Get the port on which to contact the server on this host.
56: * Defaults to the port specified in: ???
57: * @return the server port
58: */
59: int getServerPort();
60:
61: /**
62: * Set the port on which to contact the server on this host.
63: * @param serverPort the server port
64: */
65: void setServerPort(int serverPort);
66:
67: /**
68: * Get the port on which to monitor nodes running on this host.
69: * Defaults to the port specified in: ???
70: * @return the monitoring port
71: */
72: int getMonitoringPort();
73:
74: /**
75: * Set the port on which to monitor nodes running on this host.
76: * @param monitoringPort port on which to monitor nodes
77: */
78: void setMonitoringPort(int monitoringPort);
79: }
|