diff --git a/include/OneClient.h b/include/OneClient.h new file mode 100644 index 0000000000..31b9a0420e --- /dev/null +++ b/include/OneClient.h @@ -0,0 +1,237 @@ +/* -------------------------------------------------------------------------- */ +/* Copyright 2002-2008, Distributed Systems Architecture Group, Universidad */ +/* Complutense de Madrid (dsa-research.org) */ +/* */ +/* Licensed 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. */ +/* -------------------------------------------------------------------------- */ + +#ifndef ONECLIENT_H_ +#define ONECLIENT_H_ + +#include +#include + +#include + +using namespace std; + + +/** + * OneClient class. Provides a simple interface to invoke the ONE methods. This + * class can be used as base to build complex clients or VM applications + */ + +class OneClient : public xmlrpc_c::clientSimple +{ +public: + /* ---------------------------------------------------------------------- */ + /* ONE Session Constructors */ + /* ---------------------------------------------------------------------- */ + + /** + * Set the connection values to communicate with ONE + * @param oneurl the ONE front-end to interact with, defaults to "localhost". + * @param socket the socket where ONE listen to, defaults to 2633. + */ + OneClient(string oneurl="localhost",unsigned int socket=2633); + + ~OneClient(){}; + + /* ---------------------------------------------------------------------- */ + /* ONE Virtual Machine Methods */ + /* ---------------------------------------------------------------------- */ + + /** + * Add a new VM to the VM pool and starts it. + * @param template_file path, description of the Virtual Machine template + * @param vmid, the id of the new VM + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int allocate(string template_file, int& vmid, string& error); + + /** + * Deploys the virtual machine "vmid" into the host "hid". + * @param vmid the virtual machine to deploy. + * @param hid the host id to deploy the VM. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int deploy(int vmid, int hid, string& error); + + /** + * Migrate the virtual machine "vmid" to the host "hid". + * @param vmid the virtual machine to migrate. + * @param hid the destination host. + * @param live try a "live migration". + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int migrate(int vmid, int hid, bool live, string& error); + + /** + * Shutdown a virtual machine. + * @param vmid the vm identifier to shutdown. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int shutdown(int vmid, string& error) + { + return action(vmid,"shutdown",error); + }; + + /** + * Sets a VM to hold, scheduler will not deploy it. + * @param vmid the vm identifier to hold. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int hold(int vmid, string& error) + { + return action(vmid,"hold",error); + }; + + /** + * Release a VM from hold state. + * @param vmid the vm identifier to release. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int release(int vmid, string& error) + { + return action(vmid,"release",error); + }; + + /** + * Stop a running VM + * @param vmid the vm identifier to stop. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int stop(int vmid, string& error) + { + return action(vmid,"stop",error); + }; + + /** + * Saves a running VM + * @param vmid the vm identifier to suspend. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int suspend(int vmid, string& error) + { + return action(vmid,"suspend",error); + }; + + /** + * Resumes the execution of a saved VM + * @param vmid the vm identifier to resume. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int resume(int vmid, string& error) + { + return action(vmid,"resume",error); + }; + + /** + * Gets information on a virtual machine + * @param vmid the vm identifier. + * @param info the VM information + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int info(int vmid, string& info, string& error); + + /* ---------------------------------------------------------------------- */ + /* ONE Host Methods */ + /* ---------------------------------------------------------------------- */ + + /** + * Gets system info from a single host ( "hid" ). + * @param hid the host id to get for information + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int host_info(int hid, string& info, string& error); + + /** + * Removes a host from the pool + * @param hid the host id to remove + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int host_delete(int hid, string& error); + + /** + * Enables a given host. + * @param hid the host id to enable. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int host_enable(int hid, string& error) + { + return host_available(hid,true,error); + }; + + /** + * Disables a given host. + * @param hid the host id to disable. + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int host_disable(int hid, string& error) + { + return host_available(hid,false,error); + }; + + /** + * Adds a new Host to the Pool + * @param name hostname of the host to add + * @param im_mad the name of the information driver, from oned.conf + * @param vmm_mad the name of the virtual machine manager driver, from oned.conf + * @param error if an error occurs this is the error message + * @return -1 if an error occurs, 0 on success. + */ + int host_allocate(string& name, + string& im_mad, + string& vmm_mad, + string& error); +private: + + /** + * URl - url to connect to ONE. + */ + string url; + + /** + * Submits an action to be performed on a VM. + * @param vmid the VM id. + * @param action the "transition" to execute. + * @param error if an error occurs this is error message. + * @return -1 if an error occurs, otherwise 0. + */ + int action(int vmid, const char * action, string& error); + + /** + * Enables or disables a given host. + * @param hid the host id to enable/disable. + * @param enable true to enavle the target host. + * @param error if an error occurs this is error message. + * @return -1 if an error occurs, otherwise "0". + */ + int host_available(int hid, bool enable, string& error); +}; + +#endif /*ONECLIENT_H_*/