[host] windows: move log path to %ProgramData%\Looking Glass (host)

Instead of using %windir%\Temp, which is not accessible by default and
contains a lot of unrelated files, as the location for our log files,
this commit moves it to %ProgramData%\Looking Glass (host), which will
be a dedicated directory just for the LG host log files. This applies
to both the host application logs and the service logs.

Also, we now switched to using PathCombineA from shlwapi.dll instead
of using snprintf, which greatly simplifies the code. PathCombineA
guarantees that the path would not overflow a buffer of MAX_PATH.
This commit is contained in:
Quantum 2021-01-28 20:39:05 -05:00 committed by Geoffrey McRae
parent fb916cbac1
commit 1761ea2b9b
4 changed files with 39 additions and 11 deletions

View file

@ -32,6 +32,7 @@ target_link_libraries(platform_Windows
userenv userenv
wtsapi32 wtsapi32
psapi psapi
shlwapi
) )
target_include_directories(platform_Windows target_include_directories(platform_Windows

View file

@ -23,6 +23,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#include <windows.h> #include <windows.h>
#include <shellapi.h> #include <shellapi.h>
#include <shlwapi.h>
#include <fcntl.h> #include <fcntl.h>
#include "interface/platform.h" #include "interface/platform.h"
@ -34,6 +35,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#define ID_MENU_SHOW_LOG 3000 #define ID_MENU_SHOW_LOG 3000
#define ID_MENU_EXIT 3001 #define ID_MENU_EXIT 3001
#define LOG_NAME "looking-glass-host.txt"
struct AppState struct AppState
{ {
@ -44,6 +46,7 @@ struct AppState
char ** argv; char ** argv;
char executable[MAX_PATH + 1]; char executable[MAX_PATH + 1];
char systemLogDir[MAX_PATH];
HWND messageWnd; HWND messageWnd;
NOTIFYICONDATA iconData; NOTIFYICONDATA iconData;
UINT trayRestartMsg; UINT trayRestartMsg;
@ -166,6 +169,29 @@ static BOOL WINAPI CtrlHandler(DWORD dwCtrlType)
return FALSE; return FALSE;
} }
const char *getSystemLogDirectory(void)
{
return app.systemLogDir;
}
static void populateSystemLogDirectory()
{
char programData[MAX_PATH];
if (GetEnvironmentVariableA("ProgramData", programData, sizeof(programData)) &&
PathIsDirectoryA(programData))
{
if (!PathCombineA(app.systemLogDir, programData, "Looking Glass (host)"))
goto fail;
if (!PathIsDirectoryA(app.systemLogDir) && !CreateDirectoryA(app.systemLogDir, NULL))
goto fail;
return;
}
fail:
strcpy(app.systemLogDir, "");
}
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
{ {
// convert the command line to the standard argc and argv // convert the command line to the standard argc and argv
@ -180,6 +206,8 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine
LocalFree(wargv); LocalFree(wargv);
GetModuleFileName(NULL, app.executable, sizeof(app.executable)); GetModuleFileName(NULL, app.executable, sizeof(app.executable));
populateSystemLogDirectory();
if (HandleService(app.argc, app.argv)) if (HandleService(app.argc, app.argv))
return LG_HOST_EXIT_FAILED; return LG_HOST_EXIT_FAILED;
@ -201,11 +229,9 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine
int result = 0; int result = 0;
app.hInst = hInstance; app.hInst = hInstance;
char tempPath[MAX_PATH+1]; char logFilePath[MAX_PATH];
GetTempPathA(sizeof(tempPath), tempPath); if (!PathCombineA(logFilePath, app.systemLogDir, LOG_NAME))
int len = snprintf(NULL, 0, "%slooking-glass-host.txt", tempPath); strcpy(logFilePath, LOG_NAME);
char * logFilePath = malloc(len + 1);
sprintf(logFilePath, "%slooking-glass-host.txt", tempPath);
struct Option options[] = struct Option options[] =
{ {
@ -220,7 +246,6 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine
}; };
option_register(options); option_register(options);
free(logFilePath);
// setup a handler for ctrl+c // setup a handler for ctrl+c
SetConsoleCtrlHandler(CtrlHandler, TRUE); SetConsoleCtrlHandler(CtrlHandler, TRUE);

View file

@ -30,4 +30,5 @@ struct MSG_CALL_FUNCTION
LPARAM lParam; LPARAM lParam;
}; };
const char *getSystemLogDirectory(void);
LRESULT sendAppMessage(UINT Msg, WPARAM wParam, LPARAM lParam); LRESULT sendAppMessage(UINT Msg, WPARAM wParam, LPARAM lParam);

View file

@ -20,6 +20,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#include "interface/platform.h" #include "interface/platform.h"
#include "common/ivshmem.h" #include "common/ivshmem.h"
#include "service.h" #include "service.h"
#include "platform.h"
#include <stdio.h> #include <stdio.h>
#include <stdbool.h> #include <stdbool.h>
@ -29,6 +30,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#include <time.h> #include <time.h>
#include <windows.h> #include <windows.h>
#include <shlwapi.h>
#include <winsvc.h> #include <winsvc.h>
#include <psapi.h> #include <psapi.h>
#include <sddl.h> #include <sddl.h>
@ -37,6 +39,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
#define SVCNAME "Looking Glass (host)" #define SVCNAME "Looking Glass (host)"
#define SVC_ERROR ((DWORD)0xC0020001L) #define SVC_ERROR ((DWORD)0xC0020001L)
#define LOG_NAME "looking-glass-host-service.txt"
/* /*
* Windows 10 provides this API via kernel32.dll as well as advapi32.dll and * Windows 10 provides this API via kernel32.dll as well as advapi32.dll and
@ -112,11 +115,9 @@ static bool setupAPI(void)
static void setupLogging(void) static void setupLogging(void)
{ {
char tempPath[MAX_PATH+1]; char logFilePath[MAX_PATH];
GetTempPathA(sizeof(tempPath), tempPath); if (!PathCombineA(logFilePath, getSystemLogDirectory(), LOG_NAME))
int len = snprintf(NULL, 0, "%slooking-glass-host-service.txt", tempPath); strcpy(logFilePath, LOG_NAME);
char * logFilePath = malloc(len + 1);
sprintf(logFilePath, "%slooking-glass-host-service.txt", tempPath);
service.logFile = fopen(logFilePath, "a+"); service.logFile = fopen(logFilePath, "a+");
setbuf(service.logFile, NULL); setbuf(service.logFile, NULL);
doLog("Startup\n"); doLog("Startup\n");