blob: 8950b9a250cb5fb7eb76e3a2237988f3174e9c01 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional information regarding
* copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License. You may obtain a
* copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package org.apache.geode.admin.internal;
import org.apache.geode.admin.AdminDistributedSystem;
import org.apache.geode.admin.ManagedEntity;
import org.apache.geode.admin.ManagedEntityConfig;
/**
* Provides internal-only functionality that is expected of all <code>ManagedEntity<code>s. This
* functionality is used by the {@link ManagedEntityController} to manage the entity.
*
* @since GemFire 4.0
*/
public interface InternalManagedEntity extends ManagedEntity {
/** The state of a managed entity is unknown. */
int UNKNOWN = 10;
/** A managed entity is stopped */
int STOPPED = 11;
/** A managed entity is stopping (being stopped) */
int STOPPING = 12;
/** A managed entity is starting */
int STARTING = 13;
/** A managed entity is running (is started) */
int RUNNING = 14;
////////////////////// Instance Methods //////////////////////
/**
* Returns the <code>ManagedEntityConfig</code> for this <code>ManagedEntity</code>.
*/
ManagedEntityConfig getEntityConfig();
/**
* Returns a brief description (such as "locator") of this managed entity.
*/
String getEntityType();
/**
* Returns the (local) command to execute in order to start this managed entity. The command
* includes the full path to the executable (include <code>$GEMFIRE/bin</code>) and any
* command-line arguments. It does not take the {@linkplain ManagedEntityConfig#getRemoteCommand
* remote command} into account.
*/
String getStartCommand();
/**
* Returns the (local) command to execute in order to stop this managed entity.
*/
String getStopCommand();
/**
* Returns the (local) command to execute in order to determine whether or not this managed entity
* is runing.
*/
String getIsRunningCommand();
/**
* Returns a descriptive, one-word, unique id for a newly-created <code>ManagedEntity</code>. This
* ensures that we do not have collisions in the ids of entities.
*/
String getNewId();
/**
* Returns the distributed system to which this managed entity belongs.
*/
AdminDistributedSystem getDistributedSystem();
/**
* Sets the state of this managed entity and informs threads that are waiting for a state change.
* See bug 32455.
*
* @return The previous state of this managed entity.
*
* @see #RUNNING
*/
int setState(int state);
}