// Copyright 2012 Citrix Systems, Inc. Licensed under the
// Apache License, Version 2.0 (the "License"); you may not use this
// file except in compliance with the License. Citrix Systems, Inc.
// reserves all rights not expressly granted by 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.
//
// Automatically generated by addcopyright.py at 04/03/2012
package com.cloud.resource;
import com.cloud.agent.IAgentControl;
import com.cloud.agent.api.Answer;
import com.cloud.agent.api.Command;
import com.cloud.agent.api.PingCommand;
import com.cloud.agent.api.StartupCommand;
import com.cloud.host.Host;
import com.cloud.utils.component.Manager;
/**
*
* ServerResource is a generic container to execute commands sent
*/
public interface ServerResource extends Manager {
/**
* @return Host.Type type of the computing server we have.
*/
Host.Type getType();
/**
* Generate a startup command containing information regarding the resource.
* @return StartupCommand ready to be sent to the management server.
*/
StartupCommand[] initialize();
/**
* @param id id of the server to put in the PingCommand
* @return PingCommand
*/
PingCommand getCurrentStatus(long id);
/**
* Execute the request coming from the computing server.
* @param cmd Command to execute.
* @return Answer
*/
Answer executeRequest(Command cmd);
/**
* disconnected() is called when the connection is down between the
* agent and the management server. If there are any cleanups, this
* is the time to do it.
*/
void disconnected();
/**
* This is added to allow calling agent control service from within the resource
* @return
*/
IAgentControl getAgentControl();
void setAgentControl(IAgentControl agentControl);
}