/* -------------------------------------------------------------------------- */ /* Copyright 2002-2014, OpenNebula Project (OpenNebula.org), C12G Labs */ /* */ /* 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 VIRTUAL_MACHINE_HOOK_H_ #define VIRTUAL_MACHINE_HOOK_H_ #include #include #include "Hook.h" #include "VirtualMachine.h" using namespace std; /** * This class provides basic functionality to store VM states for state Hooks. * The state Map is shared by all the State hooks. A maintenance hook that * updates the map should be added. */ class VirtualMachineStateMapHook: public Hook { public: virtual void do_hook(void *arg) = 0; protected: // ------------------------------------------------------------------------- // Init the Map // ------------------------------------------------------------------------- VirtualMachineStateMapHook(const string& name, const string& cmd, const string& args, bool remote): Hook(name, cmd, args, Hook::UPDATE | Hook::ALLOCATE, remote){}; virtual ~VirtualMachineStateMapHook(){}; // ------------------------------------------------------------------------- // Functions to handle the VM state map // ------------------------------------------------------------------------- /** * Gets the state associated to the VM * @param id of the VM * @param lcm_state (previous) of the VM * @return 0 if the previous state for the VM has been recorded */ int get_state(int id, VirtualMachine::LcmState &lcm_state, VirtualMachine::VmState &vm_state); /** * Updates the state associated to the VM * @param id of the VM * @param lcm_state (current) of the VM */ void update_state (int id, VirtualMachine::LcmState lcm_state, VirtualMachine::VmState vm_state); private: struct VmStates { VmStates(VirtualMachine::LcmState _lcm, VirtualMachine::VmState _vm): lcm(_lcm), vm(_vm){}; VirtualMachine::LcmState lcm; VirtualMachine::VmState vm; }; /** * The state Map for the VMs */ static map vm_states; }; /** * This class is a general VM State Hook that executes a command locally or * remotelly when the VM gets into a given state (one shot). The VirtualMachine * object is looked when the hook is invoked. */ class VirtualMachineStateHook : public VirtualMachineStateMapHook { public: // ------------------------------------------------------------------------- // ------------------------------------------------------------------------- /** * Creates a VirtualMachineStateHook * @param name of the hook * @param cmd for the hook * @param args for the hook * @param _state the hook will be executed when the VM enters this state * @param remote the hook will be executed on the target resource */ VirtualMachineStateHook(const string& name, const string& cmd, const string& args, bool remote, VirtualMachine::LcmState _lcm, VirtualMachine::VmState _vm): VirtualMachineStateMapHook(name,cmd,args,remote), lcm(_lcm), vm(_vm){}; ~VirtualMachineStateHook(){}; // ------------------------------------------------------------------------- // Hook methods // ------------------------------------------------------------------------- void do_hook(void *arg); /** * Parses the arguments of the hook using: $ID, $TEMPLATE, $PREV_DM_STATE * and $PREV_LCM_STATE * @param obj pointer to the object executing the hook for * @param the resulting parser arguments */ void parse_hook_arguments(PoolObjectSQL * obj, VirtualMachine::VmState prev_dm, VirtualMachine::LcmState prev_lcm, string& parsed); private: /** * The target LCM state */ VirtualMachine::LcmState lcm; /** * The target DM state */ VirtualMachine::VmState vm; }; /** * This class implements a state Map updater, one hook of this type should be * added in order to mantain the VM state map. */ class VirtualMachineUpdateStateHook : public VirtualMachineStateMapHook { public: // ------------------------------------------------------------------------- // ------------------------------------------------------------------------- VirtualMachineUpdateStateHook(): VirtualMachineStateMapHook("","","",false){}; ~VirtualMachineUpdateStateHook(){}; // ------------------------------------------------------------------------- // Hook methods // ------------------------------------------------------------------------- void do_hook(void *arg); }; #endif