2004-11-20 Pierre Humblet <pierre.humblet@ieee.org>
* cygheap.h (cygheap_user::get_windows_id): New method. * registry.h (get_registry_hive_path): Change argument type. (load_registry_hive): Ditto. * registry.cc (get_registry_hive_path): Change argument type and take Win9x keys into account. (load_registry_hive): Ditto. * uinfo.cc (cygheap_user::env_userprofile): Use get_windows_id, even for SYSTEM. * shared.cc (user_shared_initialize): Use get_windows_id. * syscalls.cc (seteuid32): Load the registry hive and reload the user shared also on Win9x.
This commit is contained in:
parent
0f0fcb042a
commit
e70bea195b
|
@ -1,3 +1,17 @@
|
||||||
|
2004-11-20 Pierre Humblet <pierre.humblet@ieee.org>
|
||||||
|
|
||||||
|
* cygheap.h (cygheap_user::get_windows_id): New method.
|
||||||
|
* registry.h (get_registry_hive_path): Change argument type.
|
||||||
|
(load_registry_hive): Ditto.
|
||||||
|
* registry.cc (get_registry_hive_path): Change argument type and take
|
||||||
|
Win9x keys into account.
|
||||||
|
(load_registry_hive): Ditto.
|
||||||
|
* uinfo.cc (cygheap_user::env_userprofile): Use get_windows_id, even
|
||||||
|
for SYSTEM.
|
||||||
|
* shared.cc (user_shared_initialize): Use get_windows_id.
|
||||||
|
* syscalls.cc (seteuid32): Load the registry hive and reload the user
|
||||||
|
shared also on Win9x.
|
||||||
|
|
||||||
2004-11-11 Christopher Faylor <cgf@timesys.com>
|
2004-11-11 Christopher Faylor <cgf@timesys.com>
|
||||||
|
|
||||||
* include/cygwin/version.h: Bump DLL minor number to 13.
|
* include/cygwin/version.h: Bump DLL minor number to 13.
|
||||||
|
|
|
@ -206,6 +206,14 @@ public:
|
||||||
internal_token = NO_IMPERSONATION;
|
internal_token = NO_IMPERSONATION;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
char * get_windows_id (char * buf)
|
||||||
|
{
|
||||||
|
if (wincap.is_winnt ())
|
||||||
|
return effec_cygsid.string (buf);
|
||||||
|
else
|
||||||
|
return strcpy (buf, name ());
|
||||||
|
}
|
||||||
|
|
||||||
const char *cygheap_user::test_uid (char *&, const char *, size_t)
|
const char *cygheap_user::test_uid (char *&, const char *, size_t)
|
||||||
__attribute__ ((regparm (3)));
|
__attribute__ ((regparm (3)));
|
||||||
};
|
};
|
||||||
|
|
|
@ -194,18 +194,16 @@ reg_key::~reg_key ()
|
||||||
}
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
get_registry_hive_path (const PSID psid, char *path)
|
get_registry_hive_path (const char *name, char *path)
|
||||||
{
|
{
|
||||||
char sid[256];
|
|
||||||
char key[256];
|
char key[256];
|
||||||
HKEY hkey;
|
HKEY hkey;
|
||||||
|
|
||||||
if (!psid || !path)
|
if (!name || !path)
|
||||||
return NULL;
|
return NULL;
|
||||||
cygpsid csid (psid);
|
__small_sprintf (key, "SOFTWARE\\Microsoft\\Windows%s\\CurrentVersion\\ProfileList\\",
|
||||||
csid.string (sid);
|
wincap.is_winnt ()?" NT":"");
|
||||||
strcpy (key,"SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\ProfileList\\");
|
strcat (key, name);
|
||||||
strcat (key, sid);
|
|
||||||
if (!RegOpenKeyExA (HKEY_LOCAL_MACHINE, key, 0, KEY_READ, &hkey))
|
if (!RegOpenKeyExA (HKEY_LOCAL_MACHINE, key, 0, KEY_READ, &hkey))
|
||||||
{
|
{
|
||||||
char buf[256];
|
char buf[256];
|
||||||
|
@ -224,31 +222,31 @@ get_registry_hive_path (const PSID psid, char *path)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
load_registry_hive (PSID psid)
|
load_registry_hive (const char * name)
|
||||||
{
|
{
|
||||||
char sid[256];
|
|
||||||
char path[CYG_MAX_PATH + 1];
|
char path[CYG_MAX_PATH + 1];
|
||||||
HKEY hkey;
|
HKEY hkey;
|
||||||
LONG ret;
|
LONG ret;
|
||||||
|
|
||||||
if (!psid)
|
if (!name)
|
||||||
return;
|
return;
|
||||||
/* Check if user hive is already loaded. */
|
/* Check if user hive is already loaded. */
|
||||||
cygpsid csid (psid);
|
if (!RegOpenKeyExA (HKEY_USERS, name, 0, KEY_READ, &hkey))
|
||||||
csid.string (sid);
|
|
||||||
if (!RegOpenKeyExA (HKEY_USERS, sid, 0, KEY_READ, &hkey))
|
|
||||||
{
|
{
|
||||||
debug_printf ("User registry hive for %s already exists", sid);
|
debug_printf ("User registry hive for %s already exists", name);
|
||||||
RegCloseKey (hkey);
|
RegCloseKey (hkey);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* This is only called while deimpersonated */
|
/* This is only called while deimpersonated */
|
||||||
set_process_privilege (SE_RESTORE_NAME);
|
set_process_privilege (SE_RESTORE_NAME);
|
||||||
if (get_registry_hive_path (psid, path))
|
if (get_registry_hive_path (name, path))
|
||||||
{
|
{
|
||||||
|
if (wincap.is_winnt ())
|
||||||
strcat (path, "\\NTUSER.DAT");
|
strcat (path, "\\NTUSER.DAT");
|
||||||
if ((ret = RegLoadKeyA (HKEY_USERS, sid, path)) != ERROR_SUCCESS)
|
else
|
||||||
debug_printf ("Loading user registry hive for %s failed: %d", sid, ret);
|
strcat (path, "\\USER.DAT");
|
||||||
|
if ((ret = RegLoadKeyA (HKEY_USERS, name, path)) != ERROR_SUCCESS)
|
||||||
|
debug_printf ("Loading user registry hive for %s failed: %d", name, ret);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -39,5 +39,5 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Evaluates path to the directory of the local user registry hive */
|
/* Evaluates path to the directory of the local user registry hive */
|
||||||
char *__stdcall get_registry_hive_path (const PSID psid, char *path);
|
char *__stdcall get_registry_hive_path (const char *name, char *path);
|
||||||
void __stdcall load_registry_hive (PSID psid);
|
void __stdcall load_registry_hive (const char *name);
|
||||||
|
|
|
@ -161,15 +161,7 @@ user_shared_initialize (bool reinit)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cygwin_user_h)
|
if (!cygwin_user_h)
|
||||||
{
|
cygheap->user.get_windows_id (name);
|
||||||
if (wincap.has_security ())
|
|
||||||
{
|
|
||||||
cygpsid tu (cygheap->user.sid ());
|
|
||||||
tu.string (name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
strcpy (name, cygheap->user.name ());
|
|
||||||
}
|
|
||||||
|
|
||||||
user_shared = (user_info *) open_shared (name, USER_VERSION,
|
user_shared = (user_info *) open_shared (name, USER_VERSION,
|
||||||
cygwin_user_h, sizeof (user_info),
|
cygwin_user_h, sizeof (user_info),
|
||||||
|
|
|
@ -2008,13 +2008,16 @@ seteuid32 (__uid32_t uid)
|
||||||
user_groups &groups = cygheap->user.groups;
|
user_groups &groups = cygheap->user.groups;
|
||||||
HANDLE ptok, new_token = INVALID_HANDLE_VALUE;
|
HANDLE ptok, new_token = INVALID_HANDLE_VALUE;
|
||||||
struct passwd * pw_new;
|
struct passwd * pw_new;
|
||||||
bool token_is_internal, issamesid;
|
bool token_is_internal, issamesid = false;
|
||||||
char dacl_buf[MAX_DACL_LEN (5)];
|
char dacl_buf[MAX_DACL_LEN (5)];
|
||||||
TOKEN_DEFAULT_DACL tdacl = {};
|
TOKEN_DEFAULT_DACL tdacl = {};
|
||||||
|
|
||||||
pw_new = internal_getpwuid (uid);
|
pw_new = internal_getpwuid (uid);
|
||||||
if (!wincap.has_security () && pw_new)
|
if (!wincap.has_security () && pw_new)
|
||||||
|
{
|
||||||
|
load_registry_hive (pw_new->pw_name);
|
||||||
goto success_9x;
|
goto success_9x;
|
||||||
|
}
|
||||||
if (!usersid.getfrompw (pw_new))
|
if (!usersid.getfrompw (pw_new))
|
||||||
{
|
{
|
||||||
set_errno (EINVAL);
|
set_errno (EINVAL);
|
||||||
|
@ -2082,7 +2085,8 @@ seteuid32 (__uid32_t uid)
|
||||||
if (new_token != ptok)
|
if (new_token != ptok)
|
||||||
{
|
{
|
||||||
/* Avoid having HKCU use default user */
|
/* Avoid having HKCU use default user */
|
||||||
load_registry_hive (usersid);
|
char name[128];
|
||||||
|
load_registry_hive (usersid.string (name));
|
||||||
|
|
||||||
/* Try setting owner to same value as user. */
|
/* Try setting owner to same value as user. */
|
||||||
if (!SetTokenInformation (new_token, TokenOwner,
|
if (!SetTokenInformation (new_token, TokenOwner,
|
||||||
|
@ -2106,16 +2110,17 @@ seteuid32 (__uid32_t uid)
|
||||||
cygheap->user.set_sid (usersid);
|
cygheap->user.set_sid (usersid);
|
||||||
cygheap->user.current_token = new_token == ptok ? NO_IMPERSONATION
|
cygheap->user.current_token = new_token == ptok ? NO_IMPERSONATION
|
||||||
: new_token;
|
: new_token;
|
||||||
if (!issamesid) /* MS KB 199190 */
|
|
||||||
RegCloseKey (HKEY_CURRENT_USER);
|
|
||||||
cygheap->user.reimpersonate ();
|
cygheap->user.reimpersonate ();
|
||||||
if (!issamesid)
|
|
||||||
user_shared_initialize (true);
|
|
||||||
|
|
||||||
success_9x:
|
success_9x:
|
||||||
cygheap->user.set_name (pw_new->pw_name);
|
cygheap->user.set_name (pw_new->pw_name);
|
||||||
myself->uid = uid;
|
myself->uid = uid;
|
||||||
groups.ischanged = FALSE;
|
groups.ischanged = FALSE;
|
||||||
|
if (!issamesid) /* MS KB 199190 */
|
||||||
|
{
|
||||||
|
RegCloseKey (HKEY_CURRENT_USER);
|
||||||
|
user_shared_initialize (true);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
|
|
|
@ -419,11 +419,10 @@ cygheap_user::env_userprofile (const char *name, size_t namelen)
|
||||||
return puserprof;
|
return puserprof;
|
||||||
|
|
||||||
char userprofile_env_buf[CYG_MAX_PATH + 1];
|
char userprofile_env_buf[CYG_MAX_PATH + 1];
|
||||||
|
char win_id[UNLEN + 1]; /* Large enough for SID */
|
||||||
|
|
||||||
cfree_and_set (puserprof, almost_null);
|
cfree_and_set (puserprof, almost_null);
|
||||||
/* FIXME: Should this just be setting a puserprofile like everything else? */
|
if (get_registry_hive_path (get_windows_id (win_id), userprofile_env_buf))
|
||||||
const char *myname = winname ();
|
|
||||||
if (myname && strcasematch (myname, "SYSTEM")
|
|
||||||
&& get_registry_hive_path (sid (), userprofile_env_buf))
|
|
||||||
puserprof = cstrdup (userprofile_env_buf);
|
puserprof = cstrdup (userprofile_env_buf);
|
||||||
|
|
||||||
return puserprof;
|
return puserprof;
|
||||||
|
|
Loading…
Reference in New Issue