Add creation of administrator profile.

svn path=/trunk/; revision=7692
This commit is contained in:
Eric Kohl 2004-01-16 21:33:23 +00:00
parent 4e0b597dfa
commit 7a72b1d1a7
2 changed files with 203 additions and 12 deletions

View file

@ -1,4 +1,4 @@
# $Id: Makefile,v 1.3 2004/01/09 21:54:24 gvg Exp $ # $Id: Makefile,v 1.4 2004/01/16 21:33:23 ekohl Exp $
PATH_TO_TOP = ../.. PATH_TO_TOP = ../..
@ -8,7 +8,8 @@ TARGET_NAME = syssetup
TARGET_BASE = 0x74A30000 TARGET_BASE = 0x74A30000
TARGET_SDKLIBS = ntdll.a kernel32.a user32.a userenv.a TARGET_SDKLIBS = ntdll.a kernel32.a advapi32.a gdi32.a user32.a userenv.a
# comctl32.a
TARGET_CFLAGS = -Wall -Werror -fno-builtin TARGET_CFLAGS = -Wall -Werror -fno-builtin
@ -18,6 +19,7 @@ TARGET_CFLAGS += -D_DISABLE_TIDENTS
TARGET_LFLAGS = -nostartfiles -nostdlib TARGET_LFLAGS = -nostartfiles -nostdlib
TARGET_OBJECTS = dllmain.o install.o logfile.o TARGET_OBJECTS = dllmain.o install.o logfile.o
# wizard.o
include $(PATH_TO_TOP)/rules.mak include $(PATH_TO_TOP)/rules.mak

View file

@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/ */
/* $Id: install.c,v 1.5 2004/01/14 22:15:09 gvg Exp $ /* $Id: install.c,v 1.6 2004/01/16 21:33:23 ekohl Exp $
* *
* COPYRIGHT: See COPYING in the top level directory * COPYRIGHT: See COPYING in the top level directory
* PROJECT: ReactOS system libraries * PROJECT: ReactOS system libraries
@ -27,7 +27,9 @@
/* INCLUDES *****************************************************************/ /* INCLUDES *****************************************************************/
#include <ntos.h>
#include <windows.h> #include <windows.h>
#include <stdio.h>
#include <syssetup.h> #include <syssetup.h>
@ -37,9 +39,129 @@ VOID Wizard (VOID);
/* userenv.dll */ /* userenv.dll */
BOOL WINAPI InitializeProfiles (VOID); BOOL WINAPI InitializeProfiles (VOID);
BOOL WINAPI CreateUserProfileW (PSID Sid, LPCWSTR lpUserName);
/* GLOBALS ******************************************************************/
PSID DomainSid = NULL;
PSID AdminSid = NULL;
/* FUNCTIONS ****************************************************************/ /* FUNCTIONS ****************************************************************/
void
DebugPrint(char* fmt,...)
{
char buffer[512];
va_list ap;
va_start(ap, fmt);
vsprintf(buffer, fmt, ap);
va_end(ap);
OutputDebugStringA(buffer);
}
static VOID
CreateRandomSid (PSID *Sid)
{
SID_IDENTIFIER_AUTHORITY SystemAuthority = {SECURITY_NT_AUTHORITY};
LARGE_INTEGER SystemTime;
PULONG Seed;
NtQuerySystemTime (&SystemTime);
Seed = &SystemTime.u.LowPart;
RtlAllocateAndInitializeSid (&SystemAuthority,
4,
SECURITY_NT_NON_UNIQUE_RID,
RtlUniform (Seed),
RtlUniform (Seed),
RtlUniform (Seed),
SECURITY_NULL_RID,
SECURITY_NULL_RID,
SECURITY_NULL_RID,
SECURITY_NULL_RID,
Sid);
}
static VOID
AppendRidToSid (PSID *Dst,
PSID Src,
ULONG NewRid)
{
ULONG Rid[8] = {0, 0, 0, 0, 0, 0, 0, 0};
UCHAR RidCount;
ULONG i;
RidCount = *RtlSubAuthorityCountSid (Src);
for (i = 0; i < RidCount; i++)
Rid[i] = *RtlSubAuthoritySid (Src, i);
if (RidCount < 8)
{
Rid[RidCount] = NewRid;
RidCount++;
}
RtlAllocateAndInitializeSid (RtlIdentifierAuthoritySid (Src),
RidCount,
Rid[0],
Rid[1],
Rid[2],
Rid[3],
Rid[4],
Rid[5],
Rid[6],
Rid[7],
Dst);
}
static BOOL
SaveDomainSid (PSID Sid)
{
DWORD dwDisposition;
HKEY hKey;
if (RegCreateKeyExW (HKEY_LOCAL_MACHINE,
L"SAM\\Accounts",
0,
NULL,
REG_OPTION_NON_VOLATILE,
KEY_ALL_ACCESS,
NULL,
&hKey,
&dwDisposition))
{
#if 0
DebugPrint ("Failed to create Accounts key! (Error %lu)\n", GetLastError());
#endif
return FALSE;
}
if (RegSetValueExW (hKey,
L"DomainSID",
0,
REG_BINARY,
(LPBYTE)Sid,
RtlLengthSid (Sid)))
{
#if 0
DebugPrint ("Failed to set DomainSID value! (Error %lu)\n", GetLastError());
#endif
RegCloseKey (hKey);
return FALSE;
}
RegCloseKey (hKey);
return TRUE;
}
DWORD STDCALL DWORD STDCALL
InstallReactOS (HINSTANCE hInstance) InstallReactOS (HINSTANCE hInstance)
{ {
@ -62,23 +184,90 @@ InstallReactOS (HINSTANCE hInstance)
TerminateSetupActionLog (); TerminateSetupActionLog ();
#endif #endif
#if 0
UNICODE_STRING SidString;
#endif
if (!InitializeProfiles ())
if (InitializeProfiles())
{
MessageBoxA (NULL,
"Profiles initialized!\nRebooting now!",
"ReactOS Setup",
MB_OK);
}
else
{ {
#if 0
OutputDebugStringA ("InitializeProfiles() failed\n");
#endif
MessageBoxA (NULL, MessageBoxA (NULL,
"Profile initialization failed!\nRebooting now!", "Profile initialization failed!\nRebooting now!",
"ReactOS Setup", "ReactOS Setup",
MB_OK); MB_OK);
return 0;
} }
CreateRandomSid (&DomainSid);
if (DomainSid == NULL)
{
#if 0
OutputDebugStringA ("Failed to create the Domain-SID!\n");
#endif
MessageBoxA (NULL,
"Failed to create the Domain SID!\nRebooting now!",
"ReactOS Setup",
MB_OK);
return 0;
}
#if 0
RtlConvertSidToUnicodeString (&SidString, DomainSid, TRUE);
DebugPrint ("Domain-SID: %wZ\n", &SidString);
RtlFreeUnicodeString (&SidString);
#endif
if (!SaveDomainSid (DomainSid))
{
#if 0
OutputDebugStringA ("Failed to create the Domain-SID!\n");
#endif
MessageBoxA (NULL,
"Failed to save the Domain SID!\nRebooting now!",
"ReactOS Setup",
MB_OK);
RtlFreeSid (DomainSid);
return 0;
}
AppendRidToSid (&AdminSid, DomainSid, DOMAIN_USER_RID_ADMIN);
#if 0
RtlConvertSidToUnicodeString (&SidString, AdminSid, TRUE);
DebugPrint ("Admin SID: %wZ\n", &SidString);
RtlFreeUnicodeString (&SidString);
#endif
if (!CreateUserProfileW (AdminSid, L"Administrator"))
{
#if 0
DebugPrint ("Failed to create the admin user profile!\n");
#endif
MessageBoxA (NULL,
"Failed to create the admin user profile!\nRebooting now!",
"ReactOS Setup",
MB_OK);
RtlFreeSid (AdminSid);
RtlFreeSid (DomainSid);
return 0;
}
RtlFreeSid (AdminSid);
RtlFreeSid (DomainSid);
#if 0
OutputDebugStringA ("System setup successful\n");
#endif
MessageBoxA (NULL,
"Profile initialization successful!\nRebooting now!",
"ReactOS Setup",
MB_OK);
#if 0 #if 0
Wizard (); Wizard ();
#endif #endif