/*++ Copyright (C) 1996-2001 Microsoft Corporation Module Name: MAINDLL.CPP Abstract: Contains DLL entry points. Also has code that controls when the DLL can be unloaded by tracking the number of objects and locks. History: a-davj 15-Aug-96 Created. --*/ #include "precomp.h" #include #include #include #include #include #include #include #include #include #include #include "comobj.h" #include "mofout.h" #include "mofcomp.h" #include "mofparse.h" #include "mofdata.h" #include "bmof.h" #include "cbmofout.h" #include "trace.h" #include "strings.h" #include #include #include HINSTANCE ghModule; //*************************************************************************** // // BOOL WINAPI DllMain // // DESCRIPTION: // // Entry point for DLL. Good place for initialization. // // PARAMETERS: // // hInstance instance handle // ulReason why we are being called // pvReserved reserved // // RETURN VALUE: // // TRUE if OK. // //*************************************************************************** BOOL WINAPI DllMain( IN HINSTANCE hInstance, IN ULONG ulReason, LPVOID pvReserved) { if (DLL_PROCESS_DETACH == ulReason) { } else if (DLL_PROCESS_ATTACH == ulReason) { ghModule = hInstance; } return TRUE; } static ULONG g_cObj = 0; ULONG g_cLock = 0; void ObjectCreated() { InterlockedIncrement((LONG *) &g_cObj); } void ObjectDestroyed() { InterlockedDecrement((LONG *) &g_cObj); } //*************************************************************************** // // STDAPI DllGetClassObject // // DESCRIPTION: // // Called when Ole wants a class factory. Return one only if it is the sort // of class this DLL supports. // // PARAMETERS: // // rclsid CLSID of the object that is desired. // riid ID of the desired interface. // ppv Set to the class factory. // // RETURN VALUE: // // S_OK all is well // E_FAILED not something we support // //*************************************************************************** STDAPI DllGetClassObject( IN REFCLSID rclsid, IN REFIID riid, OUT LPVOID * ppv) { HRESULT hr = WBEM_E_FAILED; IClassFactory * pFactory = NULL; if (CLSID_WinmgmtMofCompiler == rclsid) pFactory = new CGenFactory(); else if (CLSID_MofCompiler == rclsid) pFactory = new CGenFactory(); else if (CLSID_MofCompilerOOP == rclsid) pFactory = new CGenFactory(); if(pFactory == NULL) return E_FAIL; hr=pFactory->QueryInterface(riid, ppv); if (FAILED(hr)) delete pFactory; return hr; } //*************************************************************************** // // STDAPI DllCanUnloadNow // // DESCRIPTION: // // Answers if the DLL can be freed, that is, if there are no // references to anything this DLL provides. // // RETURN VALUE: // // S_OK if it is OK to unload // S_FALSE if still in use // //*************************************************************************** STDAPI DllCanUnloadNow(void) { SCODE sc; //It is OK to unload if there are no objects or locks on the // class factory. sc=(0L==g_cObj && 0L==g_cLock) ? S_OK : S_FALSE; return sc; } //*************************************************************************** // // DllRegisterServer // // Purpose: Called during setup or by regsvr32. // // Return: NOERROR if registration successful, error otherwise. //*************************************************************************** STDAPI DllRegisterServer(void) { RegisterDLL(ghModule, CLSID_MofCompiler, __TEXT("MOF Compiler"), __TEXT("Both"), NULL); RegisterDLL(ghModule, CLSID_WinmgmtMofCompiler, __TEXT("Winmgmt MOF Compiler"), __TEXT("Both"), NULL); RegisterDllAppid(ghModule,CLSID_MofCompilerOOP,__TEXT("Winmgmt MOF Compiler OOP"), __TEXT("Both"), __TEXT("O:SYG:SYD:(D;;0x1;;;BU)(A;;0x1;;;SY)"), __TEXT("O:SYG:SYD:(D;;0x1;;;BU)(A;;0x1;;;SY)")); return NOERROR; } //*************************************************************************** // // DllUnregisterServer // // Purpose: Called when it is time to remove the registry entries. // // Return: NOERROR if registration successful, error otherwise. //*************************************************************************** STDAPI DllUnregisterServer(void) { UnRegisterDLL(CLSID_MofCompiler,NULL); UnRegisterDLL(CLSID_WinmgmtMofCompiler,NULL); UnregisterDllAppid(CLSID_MofCompilerOOP); return NOERROR; } //*************************************************************************** // // bool IsValidMulti // // DESCRIPTION: // // Does a sanity check on a multstring. // // PARAMETERS: // // pMultStr Multistring to test. // dwSize size of multistring // // RETURN: // // true if OK // //*************************************************************************** bool IsValidMulti(TCHAR * pMultStr, DWORD dwSize) { if(pMultStr && dwSize >= 2 && pMultStr[dwSize-2]==0 && pMultStr[dwSize-1]==0) return true; return false; } //*************************************************************************** // // bool IsStringPresent // // DESCRIPTION: // // Searches a multstring for the presense of a string. // // PARAMETERS: // // pTest String to look for. // pMultStr Multistring to test. // // RETURN: // // true if string is found // //*************************************************************************** bool IsStringPresent(TCHAR * pTest, TCHAR * pMultStr) { TCHAR * pTemp; for(pTemp = pMultStr; *pTemp; pTemp += lstrlen(pTemp) + 1) if(!lstrcmpi(pTest, pTemp)) return true; return false; } //*************************************************************************** // // void AddToAutoRecoverList // // DESCRIPTION: // // Adds the file to the autocompile list, if it isnt already on it. // // PARAMETERS: // // pFileName File to add // //*************************************************************************** void AddToAutoRecoverList(TCHAR * pFileName) { TCHAR cFullFileName[MAX_PATH+1]; TCHAR * lpFile; DWORD dwSize; TCHAR * pNew = NULL; TCHAR * pTest; DWORD dwNewSize = 0; DWORD dwNumChar = 0; // Get the full file name long lRet = GetFullPathName(pFileName, MAX_PATH, cFullFileName, &lpFile); if(lRet == 0) return; bool bFound = false; Registry r(WBEM_REG_WINMGMT); TCHAR *pMulti = r.GetMultiStr(TEXT("Autorecover MOFs"), dwSize); dwNumChar = dwSize / sizeof(TCHAR); // Ignore the empty string case if(dwSize == 1) { delete pMulti; pMulti = NULL; } if(pMulti) { CDeleteMe dm(pMulti); if(!IsValidMulti(pMulti, dwNumChar)) { return; // bail out, messed up multistring } bFound = IsStringPresent(cFullFileName, pMulti); if(!bFound) { // The registry entry does exist, but doesnt have this name // Make a new multistring with the file name at the end dwNewSize = dwNumChar + lstrlen(cFullFileName) + 1; pNew = new TCHAR[dwNewSize]; if(!pNew) return; memcpy(pNew, pMulti, dwSize); // Find the double null for(pTest = pNew; pTest[0] || pTest[1]; pTest++); // intentional semi // Tack on the path and ensure a double null; pTest++; StringCchCopyW(pTest, dwNewSize - (pTest - pNew), cFullFileName); pTest+= lstrlen(cFullFileName)+1; *pTest = 0; // add second numm } } else { // The registry entry just doesnt exist. Create it with a value equal to our name dwNewSize = lstrlen(cFullFileName) + 2; // note extra char for double null pNew = new TCHAR[dwNewSize]; if(!pNew) return; StringCchCopyW(pNew, dwNewSize, cFullFileName); pTest = pNew + lstrlen(pNew) + 1; *pTest = 0; // add second null } if(pNew) { r.SetMultiStr(TEXT("Autorecover MOFs"), pNew, dwNewSize*sizeof(TCHAR)); delete pNew; } FILETIME ftCurTime; LARGE_INTEGER liCurTime; TCHAR szBuff[50]; GetSystemTimeAsFileTime(&ftCurTime); liCurTime.LowPart = ftCurTime.dwLowDateTime; liCurTime.HighPart = ftCurTime.dwHighDateTime; _ui64tow(liCurTime.QuadPart, szBuff, 10); r.SetStr(TEXT("Autorecover MOFs timestamp"), szBuff); } // // //////////////////////////////////////////////// VOID inline Hex2Char(BYTE Byte,TCHAR * &pOut) { BYTE HiNibble = (Byte&0xF0) >> 4; BYTE LoNibble = Byte & 0xF; *pOut = (HiNibble<10)?(__TEXT('0')+HiNibble):(__TEXT('A')+HiNibble-10); pOut++; *pOut = (LoNibble<10)?(__TEXT('0')+LoNibble):(__TEXT('A')+LoNibble-10); pOut++; } // returns "string" representation of a buffer as a HEX number VOID Buffer2String(BYTE * pStart,DWORD dwSize,TCHAR * pOut) { for (DWORD i=0;i pHash(new WCHAR[32 + 4 + 1]); if (NULL == pHash.get()) return ERROR_OUTOFMEMORY; MD5 md5; BYTE aSignature[16]; md5.Transform( pFullLongName, dwLen * sizeof(WCHAR), aSignature ); Buffer2String(aSignature,16,pHash.get()); StringCchCopy(&pHash[32],5 ,__TEXT(".mof")); *ppHash = pHash.release(); return ERROR_SUCCESS; } DWORD g_FileSD[] = { 0x80040001, 0x00000000, 0x00000000, 0x00000000, 0x00000014, 0x00340002, 0x00000002, 0x00140000, FILE_ALL_ACCESS, 0x00000101, 0x05000000, 0x00000012, 0x00180000, FILE_ALL_ACCESS, 0x00000201, 0x05000000, 0x00000020, 0x00000220 }; // // // pFileName is already assumed to be the full path // ///////////////////////////////////////////////////// DWORD CopyFileToAutorecover(TCHAR * pFileNameRegistry, TCHAR * pFileNameAutoRecover,BOOL bIsBMOF) { // get the AutoRecover HKEY hKey; LONG lRet; lRet = RegOpenKeyExW(HKEY_LOCAL_MACHINE,WBEM_REG_WINMGMT,0, KEY_READ,&hKey); if (ERROR_SUCCESS != lRet) return lRet; OnDelete cmReg(hKey); DWORD dwType; DWORD dwReq = 0; lRet = RegQueryValueExW(hKey,L"Working Directory",0, &dwType,NULL,&dwReq); if (!(ERROR_SUCCESS == lRet && REG_EXPAND_SZ == dwType)) return lRet; if (0 == dwReq ) return lRet; wmilib::auto_buffer pWorkDir(new WCHAR[dwReq /sizeof(WCHAR)]); if (NULL == pWorkDir.get()) return ERROR_OUTOFMEMORY; lRet = RegQueryValueExW(hKey,L"Working Directory",0, &dwType,(BYTE *)pWorkDir.get(),&dwReq); if (ERROR_SUCCESS != lRet || REG_EXPAND_SZ != dwType) return lRet; DWORD cchReq = ExpandEnvironmentStrings(pWorkDir.get(),NULL,0); size_t cchTot = cchReq + sizeof("\\AutoRecover\\") + 4 + 32 + 1; wmilib::auto_buffer pWorkDirExpand(new WCHAR[cchTot]); if (NULL == pWorkDirExpand.get()) return ERROR_OUTOFMEMORY; ExpandEnvironmentStrings(pWorkDir.get(),pWorkDirExpand.get(),cchTot); WCHAR * pHashedName = NULL; lRet = ComposeName(pFileNameRegistry,&pHashedName); if (ERROR_SUCCESS != lRet) return lRet; wmilib::auto_buffer DelMe(pHashedName); StringCchCat(pWorkDirExpand.get(),cchTot,L"\\AutoRecover\\"); StringCchCat(pWorkDirExpand.get(),cchTot,pHashedName); HANDLE hSrcFile = CreateFile(pFileNameAutoRecover,GENERIC_READ,FILE_SHARE_READ,NULL, OPEN_EXISTING,0,NULL); if (INVALID_HANDLE_VALUE == hSrcFile) return GetLastError(); OnDelete cmSrc(hSrcFile); DWORD dwSize = GetFileSize(hSrcFile,NULL); HANDLE hFileMapSrc = CreateFileMapping(hSrcFile, NULL, PAGE_READONLY, 0,0, // the entire file NULL); if (NULL == hFileMapSrc) return GetLastError(); OnDelete cmMapSrc(hFileMapSrc); VOID * pData = MapViewOfFile(hFileMapSrc,FILE_MAP_READ,0,0,0); if (NULL == pData) return GetLastError(); OnDelete UnMap(pData); SECURITY_ATTRIBUTES SecAttr = {sizeof(SecAttr),g_FileSD,FALSE}; HANDLE hDest = CreateFile(pWorkDirExpand.get(),GENERIC_WRITE,0,&SecAttr, CREATE_ALWAYS,0,NULL); if (INVALID_HANDLE_VALUE == hDest) return GetLastError(); OnDelete cmDest(hDest); DWORD dwWritten; if (!bIsBMOF) { WORD UnicodeSign = 0xFEFF; if (FALSE == WriteFile(hDest,&UnicodeSign,sizeof(UnicodeSign),&dwWritten,NULL)) return GetLastError(); } if (FALSE == WriteFile(hDest,pData,dwSize,&dwWritten,NULL)) return GetLastError(); return ERROR_SUCCESS; } //*************************************************************************** // // void AddToAutoRecoverList2 // // DESCRIPTION: // // The intent is to add to the AutoRecover List // first of all, create a copy of the pre-processed file into the AutoRecover Folder // the file name will the the MD5 hash of the uppercase FULL name // Adds the file to the autocompile list, if it isnt already on it. // // // PARAMETERS: // // pFileName File to add // //*************************************************************************** void AddToAutoRecoverList2(TCHAR * pFileName, TCHAR * pAutoRecoverFileName, BOOL CopyFileOnly, BOOL bIsBMOF) { TCHAR cFullFileName[MAX_PATH+1]; TCHAR * lpFile; DWORD dwSize; TCHAR * pNew = NULL; TCHAR * pTest; DWORD dwNewSize = 0; DWORD dwNumChar = 0; // Get the full file name long lRet = GetFullPathName(pFileName, MAX_PATH, cFullFileName, &lpFile); if(lRet == 0) return; if (ERROR_SUCCESS != (lRet = CopyFileToAutorecover(cFullFileName,pAutoRecoverFileName,bIsBMOF))) { ERRORTRACE((LOG_MOFCOMP,"Error %d adding file %S to AutoRecover",lRet,pFileName)); return; } if (CopyFileOnly) return; bool bFound = false; Registry r(WBEM_REG_WINMGMT); TCHAR *pMulti = r.GetMultiStr(TEXT("Autorecover MOFs"), dwSize); dwNumChar = dwSize / sizeof(TCHAR); // Ignore the empty string case if(dwSize == 1) { delete pMulti; pMulti = NULL; } if(pMulti) { CDeleteMe dm(pMulti); if(!IsValidMulti(pMulti, dwNumChar)) { return; // bail out, messed up multistring } bFound = IsStringPresent(cFullFileName, pMulti); if(!bFound) { // The registry entry does exist, but doesnt have this name // Make a new multistring with the file name at the end dwNewSize = dwNumChar + lstrlen(cFullFileName) + 1; pNew = new TCHAR[dwNewSize]; if(!pNew) return; memcpy(pNew, pMulti, dwSize); // Find the double null for(pTest = pNew; pTest[0] || pTest[1]; pTest++); // intentional semi // Tack on the path and ensure a double null; pTest++; StringCchCopy(pTest,dwNewSize - (pTest - pNew),cFullFileName); pTest+= lstrlen(cFullFileName)+1; *pTest = 0; // add second numm } } else { // The registry entry just doesnt exist. Create it with a value equal to our name dwNewSize = lstrlen(cFullFileName) + 2; // note extra char for double null pNew = new TCHAR[dwNewSize]; if(!pNew) return; StringCchCopy(pNew,dwNewSize,cFullFileName); pTest = pNew + lstrlen(pNew) + 1; *pTest = 0; // add second null } if(pNew) { r.SetMultiStr(TEXT("Autorecover MOFs"), pNew, dwNewSize*sizeof(TCHAR)); delete pNew; } FILETIME ftCurTime; LARGE_INTEGER liCurTime; TCHAR szBuff[50]; GetSystemTimeAsFileTime(&ftCurTime); liCurTime.LowPart = ftCurTime.dwLowDateTime; liCurTime.HighPart = ftCurTime.dwHighDateTime; _ui64tow(liCurTime.QuadPart, szBuff, 10); r.SetStr(TEXT("Autorecover MOFs timestamp"), szBuff); } //*************************************************************************** // // int Trace // // DESCRIPTION: // // Allows for the output function (printf in this case) to be overridden. // // PARAMETERS: // // *fmt format string. Ex "%s hello %d" // ... argument list. Ex cpTest, 23 // // RETURN VALUE: // // size of output in characters. //*************************************************************************** int Trace(bool bError, PDBG pDbg,DWORD dwID, ...) { IntString is(dwID); TCHAR * fmt = is; TCHAR *buffer = new TCHAR[2048]; if(buffer == NULL) return 0; char *buffer2 = new char[4096]; if(buffer2 == NULL) { delete buffer; return 0; } va_list argptr; int cnt; va_start(argptr, dwID); cnt = StringCchVPrintfW(buffer, 2048, fmt, argptr); va_end(argptr); CharToOem(buffer, buffer2); if(pDbg && pDbg->m_bPrint) printf("%s", buffer2); if(bError) ERRORTRACE((LOG_MOFCOMP,"%s", buffer2)); else DEBUGTRACE((LOG_MOFCOMP,"%s", buffer2)); delete buffer; delete buffer2; return cnt; } //*************************************************************************** // // HRESULT StoreBMOF // // DESCRIPTION: // // This stores the intermediate data as a BINARY MOF instead of storing it to // the WBEM database. // // PARAMETERS: // // pObjects The intermediate data // bWMICheck If true, the the wmi checker program is automatically started // BMOFFileName file name to store the data to. // // RETURN VALUE: // // 0 if OK, otherwise an error code // //*************************************************************************** HRESULT StoreBMOF(CMofParser & Parser, CPtrArray * pObjects, BOOL bWMICheck, LPTSTR BMOFFileName, PDBG pDbg) { int i; { CBMOFOut BMof(BMOFFileName, pDbg); // Go through all the objects and add them to the database // ======================================================= for(i = 0; i < pObjects->GetSize(); i++) { CMObject* pObject = (CMObject*)(*pObjects)[i]; pObject->Reflate(Parser); BMof.AddClass(pObject, FALSE); // possibly add to the BMOF output buffer pObject->Deflate(false); } if(!BMof.WriteFile()) { return WBEM_E_FAILED; } } if(bWMICheck) { PROCESS_INFORMATION pi; STARTUPINFO si; si.cb = sizeof(si); si.lpReserved = 0; si.lpDesktop = NULL; si.lpTitle = NULL; si.dwFlags = 0; si.cbReserved2 = 0; si.lpReserved2 = 0; TCHAR App[MAX_PATH]; StringCchCopyW(App, MAX_PATH, TEXT("wmimofck ")); StringCchCatW(App, MAX_PATH, BMOFFileName); BOOL bRes = CreateProcess(NULL, App, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi); if(bRes == 0) { DWORD dwError = GetLastError(); Trace(true, pDbg, WMI_LAUNCH_ERROR, dwError); return dwError; } } return WBEM_NO_ERROR; } void SetInfo(WBEM_COMPILE_STATUS_INFO *pInfo, long lPhase, HRESULT hRes) { if(pInfo) { pInfo->lPhaseError = lPhase; pInfo->hRes = hRes; } } HRESULT ExtractAmendment(CMofParser & Parser, WCHAR * wszBmof) { // if this is being used for splitting, then possibly get the amendment value // It would be passed in the wszBmof string and would be found after // the characters ",a". For example, the string might be ",aMS_409,fFileName.mof" if(wszBmof == NULL || wszBmof[0] != L',') return S_OK; // not a problem, is usual case // make a copy of the string DWORD dwLen = wcslen(wszBmof)+1; WCHAR *pTemp = new WCHAR[dwLen]; if(pTemp == NULL) return WBEM_E_OUT_OF_MEMORY; CDeleteMe dm1(pTemp); StringCchCopyW(pTemp, dwLen, wszBmof); // use wcstok to do a seach WCHAR * token = wcstok( pTemp, L"," ); while( token != NULL ) { if(token[0] == L'a') { return Parser.SetAmendment(token+1); } token = wcstok( NULL, L"," ); } return S_OK; } SCODE Compile(CMofParser & Parser, IWbemServices *pOverride, IWbemContext * pCtx, long lOptionFlags, long lClassFlags, long lInstanceFlags, WCHAR * wszDefault, WCHAR *UserName, WCHAR *pPassword , WCHAR *Authority, WCHAR * wszBmof, bool bInProc, WBEM_COMPILE_STATUS_INFO *pInfo) { // do flag validity check if((lOptionFlags & WBEM_FLAG_DONT_ADD_TO_LIST) && (lOptionFlags & WBEM_FLAG_AUTORECOVER)) { SetInfo(pInfo, 1, WBEM_E_INVALID_PARAMETER); return S_FALSE; } long lValid = WBEM_FLAG_DONT_ADD_TO_LIST | WBEM_FLAG_AUTORECOVER | WBEM_FLAG_CHECK_ONLY | WBEM_FLAG_WMI_CHECK | WBEM_FLAG_SPLIT_FILES | WBEM_FLAG_CONSOLE_PRINT | WBEM_FLAG_CONNECT_REPOSITORY_ONLY | WBEM_FLAG_CONNECT_PROVIDERS; if(lOptionFlags & ~lValid) { SetInfo(pInfo, 1, WBEM_E_INVALID_PARAMETER); return S_FALSE; } // Init buffers for command line args. // =================================== HRESULT hres; // This scope is defined so that the local variables, such as the PARSE // object are destroyed before CoUninitialize is called. TCHAR cBMOFOutputName[MAX_PATH] = TEXT(""); if(wszBmof) CopyOrConvert(cBMOFOutputName, wszBmof, MAX_PATH); // Parse command line arguments // ============================ BOOL bCheckOnly = lOptionFlags & WBEM_FLAG_CHECK_ONLY; BOOL bWMICheck = lOptionFlags & WBEM_FLAG_WMI_CHECK; bool bAutoRecover = (lOptionFlags & WBEM_FLAG_AUTORECOVER) != 0; if(wszDefault && wcslen(wszDefault) > 0) { hres = Parser.SetDefaultNamespace(wszDefault); if(FAILED(hres)) return hres; } hres = ExtractAmendment(Parser, wszBmof); if(FAILED(hres)) return hres; Parser.SetOtherDefaults(lClassFlags, lInstanceFlags, bAutoRecover); if(!Parser.Parse()) { int nLine = 0, nCol = 0, nError; TCHAR Msg[1000]; WCHAR * pErrorFile = NULL; if(Parser.GetErrorInfo(Msg, 1000, &nLine, &nCol, &nError, &pErrorFile)) Trace(true, Parser.GetDbg(), ERROR_SYNTAX, pErrorFile, nLine, nError, //nLine+1, Msg); SetInfo(pInfo, 2, nError); return S_FALSE; } Parser.SetToNotScopeCheck(); // Autorecover is not compatible with certain flags if( ((lOptionFlags & WBEM_FLAG_DONT_ADD_TO_LIST) == 0 ) && (Parser.GetAutoRecover() || bAutoRecover) && ((lInstanceFlags & ~WBEM_FLAG_OWNER_UPDATE) || (lClassFlags & ~WBEM_FLAG_OWNER_UPDATE) || (wszDefault && wszDefault[0] != 0) || Parser.GetRemotePragmaPaths())) { Trace(true, Parser.GetDbg(), INVALID_AUTORECOVER); SetInfo(pInfo, 1, 0); return S_FALSE; } Trace(false, Parser.GetDbg(), SUCCESS); if(bCheckOnly) { Trace(false, Parser.GetDbg(), SYNTAX_CHECK_COMPLETE); SetInfo(pInfo, 0, 0); return S_OK; } CMofData* pData = Parser.AccessOutput(); if((lstrlen(cBMOFOutputName) > 0 && (lOptionFlags & WBEM_FLAG_SPLIT_FILES)) || Parser.GetAmendment()) { hres = pData->Split(Parser, wszBmof, pInfo, Parser.IsUnicode(), Parser.GetAutoRecover(), Parser.GetAmendment()); if(hres != S_OK) { SetInfo(pInfo, 3, hres); return S_FALSE; } else { SetInfo(pInfo, 0, 0); return S_OK; } } else if(lstrlen(cBMOFOutputName)) { if(Parser.IsntBMOFCompatible()) { Trace(true, Parser.GetDbg(), BMOF_INCOMPATIBLE); SetInfo(pInfo, 3, WBEM_E_INVALID_PARAMETER); return S_FALSE; } Trace(false, Parser.GetDbg(), STORING_BMOF, cBMOFOutputName); CPtrArray * pObjArray = pData->GetObjArrayPtr(); SCODE sc = StoreBMOF(Parser, pObjArray, bWMICheck, cBMOFOutputName, Parser.GetDbg()); if(sc != S_OK) { SetInfo(pInfo, 3, sc); return S_FALSE; } else { SetInfo(pInfo, 0, 0); return S_OK; } } IWbemLocator* pLocator = NULL; hres = CoCreateInstance( (bInProc) ? CLSID_WbemAdministrativeLocator : CLSID_WbemLocator, NULL, CLSCTX_ALL, IID_IWbemLocator, (void**)&pLocator); if(FAILED(hres)) { SetInfo(pInfo, 3, hres); return S_FALSE; } Trace(false, Parser.GetDbg(), STORING_DATA); hres = pData->Store(Parser, pLocator, pOverride, TRUE,UserName, pPassword , Authority, pCtx, (bInProc) ? CLSID_WbemAdministrativeLocator : CLSID_WbemLocator, pInfo, lClassFlags & WBEM_FLAG_OWNER_UPDATE, lInstanceFlags & WBEM_FLAG_OWNER_UPDATE, lOptionFlags & (WBEM_FLAG_CONNECT_PROVIDERS|WBEM_FLAG_CONNECT_REPOSITORY_ONLY)); if(pLocator != NULL) pLocator->Release(); if(hres != S_OK) { SetInfo(pInfo, 3, hres); return S_FALSE; } else { if(Parser.GetFileName() && wcslen(Parser.GetFileName())) ERRORTRACE((LOG_MOFCOMP,"Finished compiling file:%ls\n", Parser.GetFileName())); _variant_t VarDoStore = false; BOOL OverrideAutoRecover = FALSE; if (pCtx) pCtx->GetValue(L"__MOFD_DO_STORE",0,&VarDoStore); if (VT_BOOL == V_VT(&VarDoStore) && (VARIANT_TRUE == V_BOOL(&VarDoStore))) { OverrideAutoRecover = TRUE; } if(Parser.GetAutoRecover() || OverrideAutoRecover) { if(lOptionFlags & WBEM_FLAG_DONT_ADD_TO_LIST) { if(pInfo) pInfo->dwOutFlags |= AUTORECOVERY_REQUIRED; } //Call MOF Compiler with (pszMofs); _variant_t Var = false; if (pCtx) pCtx->GetValue(L"__MOFD_NO_STORE",0,&Var); if (VT_BOOL == V_VT(&Var) && (VARIANT_TRUE == V_BOOL(&Var))) { } else { AddToAutoRecoverList2(Parser.GetFileName(), Parser.GetAutoRecoverFileName(), lOptionFlags & WBEM_FLAG_DONT_ADD_TO_LIST, Parser.IsBMOF()); } } SetInfo(pInfo, 0, 0); return S_OK; } }