|
|
/****************************************************************************
Copyright information : Copyright (c) 1998-1999 Microsoft Corporation File Name : ExecEngine.h Project Name : WMI Command Line Author Name : Ch. Sriramachandramurthy Date of Creation (dd/mm/yy) : 27th-September-2000 Version Number : 1.0 Brief Description : This file consist of member variable and functions declarations of the Execution engine module. Revision History : Last Modified By : Ch. Sriramachandramurthy Last Modified Date : 20th-March-2001 ****************************************************************************/
/*-------------------------------------------------------------------
Class Name : CExecEngine Class Type : Concrete Brief Description : This class encapsulates the functionality needed for executing the WMI statements that are obtained as a result of parsing engine. It also performs verb specific processing using the information available with CParsedInfo class. Super Classes : None Sub Classes : None Classes Used : CParsedInfo Interfaces Used : WMI COM Interfaces --------------------------------------------------------------------*/
class CParsedInfo;
class CExecEngine { public: // Construction
CExecEngine();
// Destruction
~CExecEngine();
// Restrict Assignment
CExecEngine& operator=(CExecEngine& rExecEngine);
// Attributes
private: // trace flag
BOOL m_bTrace;
ERRLOGOPT m_eloErrLogOpt; // Pointer to object of type IWbemObjectTextSrc encapsulates the
// functionality of WMI XML Encoder
IWbemObjectTextSrc *m_pITextSrc; // Pointer to object of type IWbemLocator, used to obtain IWbemServices
// object.
IWbemLocator *m_pIWbemLocator; // Pointer to object of type IWbemServices, Used to perform WMI operations
// on target namespace.
IWbemServices *m_pITargetNS;
// Context pointer
IWbemContext *m_pIContext;
BOOL m_bSysProp;
BOOL m_bNoAssoc; // Operations
private: // Creates the instance of IWbemObjectTextSrc interface.
HRESULT CreateWMIXMLTextSrc(CParsedInfo& rParsedInfo);
// Creates the instance of IWbemContext interface
HRESULT CreateContext(CParsedInfo& rPrasedInfo);
// Connect to the WMI namespace on the target machine.
HRESULT ConnectToTargetNS(CParsedInfo& rParsedInfo);
// Executes query to give results in XML file format.
// Refers data in the CCommnadSwicthes object of CParsedInfo object.
HRESULT ObtainXMLResultSet(BSTR bstrQuery, CParsedInfo& rParsedInfo, _bstr_t& bstrXML, BOOL bSysProp = TRUE, BOOL bNotAssoc = TRUE);
HRESULT FrameAssocHeader(_bstr_t bstrPath, _bstr_t& bstrFrag, BOOL bClass);
// This function changes the property value for the
// given property name and value
BOOL SetPropertyInfo(CParsedInfo& rParsedInfo, _bstr_t& bstrQuery, _bstr_t& bstrObject); // Executes a WMI method specified in the CCommandSwicthes
// object of the CParsedInfo object passed to it.
BOOL ExecWMIMethod(CParsedInfo&); // Processes and executes GET|LIST verb referring CParsedInfo object
// or to display help in interactive mode by displaying properties of
// concernrd instance.
BOOL ProcessSHOWInfo(CParsedInfo& rParsedInfo, BOOL bVerb=TRUE, _TCHAR* pszPath=NULL); // Processes and executes CALL verb referring CParsedInfo object.
BOOL ProcessCALLVerb(CParsedInfo& rParsedInfo); // Processes and executes SET verb referring CParsedInfo object.
BOOL ProcessSETVerb(CParsedInfo& rParsedInfo); // Processes and executes CREATE verb referring CParsedInfo object.
BOOL ProcessCREATEVerb(CParsedInfo& rParsedInfo);
// Processes and executes DELETE verb referring CParsedInfo object.
BOOL ProcessDELETEVerb(CParsedInfo& rParsedInfo);
// Processes and executes ASSOC verb referring CParsedInfo object.
BOOL ProcessASSOCVerb(CParsedInfo& rParsedInfo); // This function constructs the path expression from alias info and
// where info. Used for CALL verb only
BOOL FormPathExprFromWhereExpr(_bstr_t& bstrPath, CParsedInfo& rParsedInfo);
// This function changes the property values for the given property names
// and values in a passed IWbemClassObject
BOOL SetProperties(CParsedInfo& rParsedInfo, IWbemClassObject* pIWbemObj, BOOL bClass);
// Deletes the objects
BOOL DeleteObjects(CParsedInfo& rParsedInfo, _bstr_t& bstrQuery, _bstr_t& bstrObject);
// Obtain user response
INTEROPTION GetUserResponse(_TCHAR* pszMsg);
// Create a new instance
BOOL CreateInstance(CParsedInfo& rParsedInfo, BSTR bstrClass);
// Validate the new input values supplied for the properties
// against the qualifiers details.
BOOL ValidateInParams(CParsedInfo& rParsedInfo, _bstr_t bstrClass);
BOOL ValidateAlaisInParams(CParsedInfo& rParsedInfo);
BOOL CheckAliasQualifierInfo(CParsedInfo& rParsedInfo, _bstr_t bstrParam, WCHAR*& pszValue, PROPDETMAP pdmPropDetMap); // Checks the parameter/property value against the following
// qualifiers:
// 1. MaxLen, 2. Values 3. ValuesMap
BOOL CheckQualifierInfo(CParsedInfo& rParsedInfo, IWbemClassObject* pIObject, _bstr_t bstrParam, WCHAR*& pszValue);
// Method Execution
HRESULT ExecuteMethodAndDisplayResults(_bstr_t bstrPath, CParsedInfo& rParsedinfo, IWbemClassObject* pIInParam);
// Display the output parameters of method execution.
void DisplayMethExecOutput(CParsedInfo& rParsedInfo);
// Invoke other command line Utilities
BOOL ExecOtherCmdLineUtlty(CParsedInfo& rParsedInfo);
// Checks and returns TRUE if verb invocation mode is interactive
BOOL IsInteractive(CParsedInfo& rParsedInfo);
// Substitute hashes and execute command line utility.
// If pIWbemObj != NULL then utility should be passed with appropriate
// instance values.
void SubstHashAndExecCmdUtility(CParsedInfo& rParsedInfo, IWbemClassObject *pIWbemObj = NULL);
// Forms query and executes method or command line utility.
HRESULT FormQueryAndExecuteMethodOrUtility( CParsedInfo& rParsedInfo, IWbemClassObject *pIInParam = NULL);
// This function takes the input as a path expression and
// extracts the Class and Where expression part from the
// path expression.
BOOL ExtractClassNameandWhereExpr(_TCHAR* pszPathExpr, CParsedInfo& rParsedInfo, _TCHAR* pszWhere);
// This function accepts the user response before going
// ahead, when /INTERACTIVE is specified at the verb level
INTEROPTION GetUserResponseEx(_TCHAR* pszMsg);
// Obtain param values from parameter map in the same order as they
// appear in the alias verb definition.
void ObtainInParamsFromParameterMap(CParsedInfo& rParsedinfo, CHARVECTOR& cvParamValues);
HRESULT CheckForArray(IWbemClassObject* pIObj, BSTR bstrProp, VARIANT& varDest, BSTRVECTOR& vArrayValues,CParsedInfo& rParsedInfo);
void GetArrayFromToken(_TCHAR* pszValue, BSTRVECTOR& vArrayValues);
BOOL IsArrayType(IWbemClassObject* pIObj, BSTR bstrProp);
public: // This function uninitializes the member variables.
void Uninitialize(BOOL bFlag = FALSE); // Executes the command referring to CCommandSwitches and CGlobalSwitches
// of the CParsedInfo object of CParsedInfo object Passed to it as
// parameters. Puts the results back in to objects passed to it for the
// use of Format Engine.
BOOL ExecuteCommand(CParsedInfo& rParsedInfo); // Sets the locator object passed via parameter to member
// of the class.
BOOL SetLocatorObject(IWbemLocator* pILocator); };
|