services: Create service environment when first service is started.
This commit is contained in:
parent
f0d8c3383e
commit
8141fb80eb
|
@ -1,7 +1,7 @@
|
||||||
EXTRADEFS = -DWINE_NO_UNICODE_MACROS
|
EXTRADEFS = -DWINE_NO_UNICODE_MACROS
|
||||||
MODULE = services.exe
|
MODULE = services.exe
|
||||||
APPMODE = -mconsole
|
APPMODE = -mconsole
|
||||||
IMPORTS = rpcrt4 advapi32
|
IMPORTS = rpcrt4 advapi32 userenv
|
||||||
|
|
||||||
C_SRCS = \
|
C_SRCS = \
|
||||||
rpc.c \
|
rpc.c \
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <winsvc.h>
|
#include <winsvc.h>
|
||||||
#include <rpc.h>
|
#include <rpc.h>
|
||||||
|
#include <userenv.h>
|
||||||
|
|
||||||
#include "wine/unicode.h"
|
#include "wine/unicode.h"
|
||||||
#include "wine/debug.h"
|
#include "wine/debug.h"
|
||||||
|
@ -40,6 +41,7 @@ struct scmdatabase *active_database;
|
||||||
|
|
||||||
DWORD service_pipe_timeout = 10000;
|
DWORD service_pipe_timeout = 10000;
|
||||||
DWORD service_kill_timeout = 20000;
|
DWORD service_kill_timeout = 20000;
|
||||||
|
static void *env = NULL;
|
||||||
|
|
||||||
static const int is_win64 = (sizeof(void *) > sizeof(int));
|
static const int is_win64 = (sizeof(void *) > sizeof(int));
|
||||||
|
|
||||||
|
@ -581,6 +583,17 @@ static DWORD service_start_process(struct service_entry *service_entry, HANDLE *
|
||||||
|
|
||||||
service_lock_exclusive(service_entry);
|
service_lock_exclusive(service_entry);
|
||||||
|
|
||||||
|
if (!env)
|
||||||
|
{
|
||||||
|
HANDLE htok;
|
||||||
|
|
||||||
|
if (OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY|TOKEN_DUPLICATE, &htok))
|
||||||
|
CreateEnvironmentBlock(&env, htok, FALSE);
|
||||||
|
|
||||||
|
if (!env)
|
||||||
|
WINE_ERR("failed to create services environment\n");
|
||||||
|
}
|
||||||
|
|
||||||
size = ExpandEnvironmentStringsW(service_entry->config.lpBinaryPathName,NULL,0);
|
size = ExpandEnvironmentStringsW(service_entry->config.lpBinaryPathName,NULL,0);
|
||||||
path = HeapAlloc(GetProcessHeap(),0,size*sizeof(WCHAR));
|
path = HeapAlloc(GetProcessHeap(),0,size*sizeof(WCHAR));
|
||||||
if (!path)
|
if (!path)
|
||||||
|
@ -632,7 +645,7 @@ static DWORD service_start_process(struct service_entry *service_entry, HANDLE *
|
||||||
|
|
||||||
service_unlock(service_entry);
|
service_unlock(service_entry);
|
||||||
|
|
||||||
r = CreateProcessW(NULL, path, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi);
|
r = CreateProcessW(NULL, path, NULL, NULL, FALSE, CREATE_UNICODE_ENVIRONMENT, env, NULL, &si, &pi);
|
||||||
HeapFree(GetProcessHeap(),0,path);
|
HeapFree(GetProcessHeap(),0,path);
|
||||||
if (!r)
|
if (!r)
|
||||||
{
|
{
|
||||||
|
@ -867,5 +880,7 @@ int main(int argc, char *argv[])
|
||||||
RPC_MainLoop();
|
RPC_MainLoop();
|
||||||
}
|
}
|
||||||
scmdatabase_destroy(active_database);
|
scmdatabase_destroy(active_database);
|
||||||
|
if (env)
|
||||||
|
DestroyEnvironmentBlock(env);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue