/* $Id: VBoxCredProvUtils.cpp 82968 2020-02-04 10:35:17Z vboxsync $ */ /** @file * VBoxCredProvUtils - Misc. utility functions for VBoxCredProv. */ /* * Copyright (C) 2012-2020 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ /********************************************************************************************************************************* * Header Files * *********************************************************************************************************************************/ #include #include #include #ifdef LOG_ENABLED # include #endif #include /********************************************************************************************************************************* * Global Variables * *********************************************************************************************************************************/ /** Verbosity flag for guest logging. */ DWORD g_dwVerbosity = 0; /** * Displays a verbose message. * * @param dwLevel Minimum log level required to display this message. * @param pszFormat The message text. * @param ... Format arguments. */ void VBoxCredProvVerbose(DWORD dwLevel, const char *pszFormat, ...) { if (dwLevel <= g_dwVerbosity) { va_list args; va_start(args, pszFormat); char *psz = NULL; RTStrAPrintfV(&psz, pszFormat, args); va_end(args); AssertPtr(psz); LogRel(("%s", psz)); #ifdef LOG_ENABLED PRTSTREAM pStream; int rc2 = RTStrmOpen("C:\\VBoxCredProvLog.txt", "a", &pStream); if (RT_SUCCESS(rc2)) { RTStrmPrintf(pStream, "%s", psz); RTStrmClose(pStream); } #endif RTStrFree(psz); } } /** * Reports VBoxGINA's status to the host (treated as a guest facility). * * @return IPRT status code. * @param enmStatus Status to report to the host. */ int VBoxCredProvReportStatus(VBoxGuestFacilityStatus enmStatus) { VBoxCredProvVerbose(0, "VBoxCredProv: reporting status %d\n", enmStatus); int rc = VbglR3AutoLogonReportStatus(enmStatus); if (RT_FAILURE(rc)) VBoxCredProvVerbose(0, "VBoxCredProv: failed to report status %d, rc=%Rrc\n", enmStatus, rc); return rc; }