117 lines
4 KiB
PowerShell
117 lines
4 KiB
PowerShell
. "$PSScriptRoot/../Scripts/Context.ps1";
|
|
$uacDisablerName = "PortValhalla UAC Disabler";
|
|
$cleanupName = "PortValhalla Cleanup";
|
|
|
|
function New-PersonalUser([Context] $context)
|
|
{
|
|
if (-not (Get-LocalUser $context.UserName))
|
|
{
|
|
Write-Host "Creating Personal User";
|
|
|
|
while ($true) {
|
|
Write-Host (
|
|
[string]::Join(
|
|
"`n",
|
|
"So... Windows is too dumb to create users which are bound to a Microsoft Account.",
|
|
"Thus, you have to do it by yourself.",
|
|
"So sorry..."));
|
|
|
|
$users = Get-LocalUser | ForEach-Object { $_.Name };
|
|
Write-Host "Following users exist already:"
|
|
Write-Host $users;
|
|
Read-Host "Please hit enter once you're done...";
|
|
|
|
$user = Get-LocalUser | Where-Object { -not ($users -contains $_.Name) } | Select-Object -Last 1;
|
|
|
|
if ($user) {
|
|
Write-Information "Found New User:";
|
|
Write-Information $user;
|
|
break;
|
|
}
|
|
}
|
|
|
|
Write-Information "Renaming the new User to $($context.UserName)";
|
|
Rename-LocalUser $user $context.UserName;
|
|
Add-LocalGroupMember -Group "Administrators" -Member $user && Set-LocalUser $context.AdminName -Password (ConvertTo-SecureString -AsPlainText "Admin") && Disable-LocalUser $context.AdminName;
|
|
|
|
Write-Host "Registering setup script for all new users";
|
|
$context.RegisterNewUserReboot();
|
|
|
|
Write-Information "Enabling UAC for the next login (Microsoft Account login won't work otherwise, lol)";
|
|
Enable-UACNextLogin;
|
|
|
|
Write-Information "Disabling Auto login";
|
|
$context.RemoveAutologin();
|
|
Restart-Computer;
|
|
exit;
|
|
}
|
|
elseif ((Get-ScheduledTask $uacDisablerName))
|
|
{
|
|
while ((Get-ScheduledTask $uacDisablerName) -ne "Ready")
|
|
{
|
|
Start-Sleep 1;
|
|
}
|
|
|
|
$taskInfo = Get-ScheduledTask $uacDisablerName;
|
|
|
|
if ($taskInfo.LastTaskResult -ne 0)
|
|
{
|
|
Write-Error "Disabling UAC was unsuccessful.";
|
|
}
|
|
|
|
Start-ScheduledTask $cleanupName;
|
|
Enable-CurrentUserAutologon $context;
|
|
}
|
|
}
|
|
|
|
function Enable-UACNextLogin() {
|
|
$keyPath = "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System";
|
|
$propertyName = "EnableLUA";
|
|
$null = Set-ItemProperty "$keyPath" -Name "$propertyName" -Value 1;
|
|
|
|
$action = New-ScheduledTaskAction -Execute "pwsh.exe" -Argument (
|
|
[string]::Join(
|
|
" ",
|
|
@(
|
|
"-c",
|
|
"Set-ItemProperty `"$keyPath`" -Name `"$propertyName`" -Value 0;")));
|
|
|
|
$trigger = New-ScheduledTaskTrigger -AtLogOn;
|
|
$principal = New-ScheduledTaskPrincipal -UserId "SYSTEM" -RunLevel Highest;
|
|
$task = New-ScheduledTask -Action $action -Principal $principal -Trigger $trigger;
|
|
$null = Register-ScheduledTask $uacDisablerName -InputObject $task;
|
|
|
|
$action = New-ScheduledTaskAction -Execute "pwsh.exe" -Argument (
|
|
[string]::Join(
|
|
" ",
|
|
@(
|
|
"-c",
|
|
"Unregister-ScheduledTask -Force $uacDisablerName;",
|
|
"Unregister-ScheduledTask -Force $cleanupName;")));
|
|
|
|
$task = New-ScheduledTask -Action $action -Principal $principal;
|
|
$null = Register-ScheduledTask $cleanupName -InputObject $task;
|
|
}
|
|
|
|
function Enable-CurrentUserAutologon([Context] $context)
|
|
{
|
|
Add-Type -assemblyname System.DirectoryServices.AccountManagement;
|
|
Write-Information "Re-Enabling Autologin for Current User";
|
|
$principalContext = [System.DirectoryServices.AccountManagement.PrincipalContext]::new("Machine");
|
|
|
|
while ($true)
|
|
{
|
|
$password = Read-Host "Please enter the password of your user" -MaskInput;
|
|
|
|
if ($principalContext.ValidateCredentials($context.UserName, $password))
|
|
{
|
|
break;
|
|
}
|
|
else {
|
|
Write-Error "The specified password is incorrect!";
|
|
}
|
|
}
|
|
|
|
$context.SetAutologin($context.UserName, $password);
|
|
}
|