PortValhalla/scripts/Windows/Scripts/Context.ps1

276 lines
8.9 KiB
PowerShell
Raw Normal View History

class Context {
2023-06-21 20:04:18 +00:00
[string]$EntryPoint;
2023-06-16 18:24:37 +00:00
[string]$RootDir;
[string]$BackupName;
2023-06-22 20:56:43 +00:00
[string]$UserName;
2023-06-22 21:04:13 +00:00
[string]$AdminName = "Admin";
[string]$ConfigRoot = "HKLM:\Software\PortValhalla";
[string]$RunOnceName = "PortValhalla";
[string]$StagePropertyName = "Stage";
[string] ProjectRoot() {
return Resolve-Path (Join-Path $PSScriptRoot ".." ".." "..");
}
[string] BackupRoot() {
2023-06-16 18:24:37 +00:00
if (-not $this.RootDir)
{
return Join-Path $this.ProjectRoot() $this.BackupName;
2023-06-16 18:24:37 +00:00
}
else
{
return $this.RootDir;
}
}
[Microsoft.Win32.RegistryKey] EnsureConfigKey() {
if (-not (Test-Path $this.ConfigRoot)) {
2023-06-29 17:11:41 +00:00
$null = New-Item $this.ConfigRoot;
2023-06-29 18:02:12 +00:00
$acl = Get-Acl $this.ConfigRoot;
$acl.AddAccessRule(
[System.Security.AccessControl.RegistryAccessRule]::new(
2023-06-29 22:55:42 +00:00
[System.Security.Principal.SecurityIdentifier]::new([System.Security.Principal.WellKnownSidType]::BuiltinUsersSid, $null),
2023-06-29 18:02:12 +00:00
[System.Security.AccessControl.RegistryRights]::FullControl,
[System.Security.AccessControl.InheritanceFlags]::ObjectInherit -bor [System.Security.AccessControl.InheritanceFlags]::ContainerInherit,
[System.Security.AccessControl.PropagationFlags]::None,
[System.Security.AccessControl.AccessControlType]::Allow));
2023-06-29 23:57:45 +00:00
Set-Acl $this.ConfigRoot $acl;
}
return Get-Item $this.ConfigRoot;
}
[object] Get([string] $key) {
$configKey = $this.EnsureConfigKey();
if ($configKey.GetValueNames().Contains($key)) {
return $configKey.GetValue($key);
} else {
return $null;
}
}
[void] Set([string] $key, $value, [Microsoft.Win32.RegistryValueKind] $type) {
$configKey = $this.EnsureConfigKey();
2023-06-30 00:40:15 +00:00
$null = Set-ItemProperty -Path $configKey.PSPath -Name $key -Value $value -Type $type;
}
[void] Remove([string] $key) {
$configKey = $this.EnsureConfigKey();
$null = Remove-ItemProperty -Path $configKey.PSPath -Name $key;
}
[void] SetStage([string] $name) {
$this.Set($this.StagePropertyName, $name, "ExpandString");
}
[string] GetStage() {
return $this.Get($this.StagePropertyName);
}
[void] RemoveStage() {
$this.Remove($this.StagePropertyName);
}
[string] ArchivePath($name) {
return Join-Path $this.BackupRoot() "$name.7z";
}
[string] FileArchivePath($name) {
return $this.ArchivePath($(Join-Path "Files" $name));
}
[string] SoftwareArchive([string]$softwareName) {
return $this.ArchivePath($softwareName);
}
[void] Backup([string]$sourcePath, [string]$archivePath, [string[]]$arguments) {
if (Test-Path $archivePath) {
Remove-Item -Recurse $archivePath;
}
Start-Process -WorkingDirectory "$sourcePath" `
-FilePath "7z" `
-ArgumentList (
@(
"a",
"-xr!desktop.ini",
2023-06-09 16:21:26 +00:00
"-xr!thumbs.db",
"-xr!Thumbs.db",
$archivePath) + $arguments) `
-Wait `
-NoNewWindow;
}
2023-06-16 18:24:22 +00:00
[void] Restore([string]$archivePath, [string]$destinationPath) {
if (-not (Test-Path -PathType Leaf $archivePath)) {
Write-Information (
[string]::Join(
"`n",
@(
"An archive at the specified path $archivePath does not exist.",
"No restoration will be performed.")));
}
else {
if (-not (Test-Path -PathType Container $destinationPath)) {
New-Item -ItemType Directory "$destinationPath";
}
Start-Process -WorkingDirectory "$destinationPath" `
-FilePath "7z"
-ArgumentList "x" `
-Wait `
-NoNewWindow;
2023-06-16 18:24:22 +00:00
}
}
[string] GetTempDirectory() {
$tempDir = Join-Path $([System.IO.Path]::GetTempPath()) $([System.IO.Path]::GetRandomFileName());
$null = New-Item -ItemType Directory $tempDir;
return $tempDir;
}
2023-06-22 20:58:54 +00:00
[void] ProcessDefaultUserKey([System.Action[Microsoft.Win32.RegistryKey]] $action) {
$rootPath = "HKLM:\DefaultUser";
$regRootPath = $rootPath.Replace(":", "");
2023-06-25 15:57:23 +00:00
$hivePath = "$env:SystemDrive\Users\Default\NTUSER.dat"
$null = & reg load $regRootPath $hivePath;
$root = Get-Item $rootPath;
$action.Invoke($root);
$root.Handle.Close();
[System.GC]::Collect();
& reg unload $regRootPath;
}
2023-06-25 16:25:52 +00:00
[void] ProcessLogonKey([System.Action[Microsoft.Win32.RegistryKey]] $action) {
$key = Get-Item "HKLM:\Software\Microsoft\Windows NT\CurrentVersion\Winlogon";
$action.Invoke($key);
}
[Microsoft.Win32.RegistryKey] GetRunOnceKey() {
return $this.GetRunOnceKey($null);
}
[Microsoft.Win32.RegistryKey] GetRunOnceKey([Microsoft.Win32.RegistryKey] $userKey) {
if (-not $userKey) {
$userKey = Get-Item "HKCU:\";
}
2023-06-25 14:33:04 +00:00
Push-Location $userKey.PSPath;
2023-06-25 16:05:55 +00:00
$runOncePath = "Software\Microsoft\Windows\CurrentVersion\RunOnce";
if (-not (Test-Path $runOncePath)) {
New-Item $runOncePath;
}
$result = Get-Item $runOncePath;
2023-06-25 14:28:12 +00:00
Pop-Location;
2023-06-25 14:54:10 +00:00
return $result;
}
[void] RegisterReboot() {
$this.RegisterReboot($null);
}
[void] RegisterReboot([Microsoft.Win32.RegistryKey] $userKey) {
$runOnceKey = $this.GetRunOnceKey($userKey);
2023-06-28 11:43:20 +00:00
Set-ItemProperty -Path $runOnceKey.PSPath -Name $this.RunOnceName -Value "pwsh `"$($this.EntryPoint)`"" -Type "ExpandString";
$runOnceKey.Handle.Close();
}
[void] RegisterNewUserReboot() {
$this.ProcessDefaultUserKey({ param ($root) $this.RegisterReboot($root); });
}
[void] DeregisterNewUserReboot() {
2023-06-25 16:10:23 +00:00
$this.ProcessDefaultUserKey({ param ($root) Remove-Item -Path $this.GetRunOnceKey($root).PSPath });
}
2023-06-25 16:25:52 +00:00
[void] SetAutologin($user, $pw) {
$this.ProcessLogonKey(
{
param ($logon)
$path = $logon.PSPath;
Set-ItemProperty $path -Name "AutoAdminLogon" 1;
Set-ItemProperty $path -Name "DefaultUserName" $user;
2023-06-30 02:47:31 +00:00
if ($pw) {
Set-ItemProperty $path -Name "DefaultPassword" $pw;
2023-06-25 16:25:52 +00:00
} else {
Remove-ItemProperty $path -Name "DefaultPassword";
}
});
}
[void] RemoveAutologin() {
$this.ProcessLogonKey(
{
param ($logon)
$path = $logon.PSPath;
2023-06-25 16:48:13 +00:00
Set-ItemProperty $path -Name "AutoAdminLogon" 0;
2023-06-25 16:25:52 +00:00
Remove-ItemProperty $path -Name "DefaultDomainName";
Remove-ItemProperty $path -Name "DefaultUserName";
Remove-ItemProperty $path -Name "DefaultPassword";
});
}
2023-06-30 11:17:00 +00:00
[string] GetNextcloudConfigFile() {
return "$env:APPDATA/Nextcloud/nextcloud.cfg";
}
2023-07-02 13:44:47 +00:00
[void] AddNextcloudSync([string] $localPath, [string] $targetPath) {
$this.AddNextcloudSync($localPath, $targetPath, $false);
}
[void] AddNextcloudSync([string] $localPath, [string] $targetPath, [bool] $virtualFiles) {
2023-07-02 15:38:44 +00:00
$pattern = "^\d+\\Folders(?:WithPlaceholders)?\\(\d+)";
$nextcloudProcess = Get-Process nextcloud;
$nextcloudPath = $nextcloudProcess.Path;
$nextcloudProcess | Stop-Process -Force;
2023-07-02 13:44:47 +00:00
$folderID = (
Get-Content $($this.GetNextcloudConfigFile()) | `
Where-Object { $_ -match "$pattern" } | `
ForEach-Object { $_ -replace "$pattern.*$","`$1" } | `
Sort-Object -Unique | `
Measure-Object -Maximum).Maximum + 1;
2023-07-02 18:45:25 +00:00
$configName = "Folders";
2023-07-02 19:49:00 +00:00
$localPath = $localPath.Replace("\", "/");
$targetPath = $targetPath.Replace("\", "/");
2023-07-02 13:44:47 +00:00
2023-07-02 18:45:25 +00:00
if ($virtualFiles) {
$configName += "WithPlaceholders";
}
$accountSectionEntered = $false;
Get-Content $($this.GetNextcloudConfigFile()) | `
ForEach-Object {
if ($_ -eq "[Accounts]") {
$accountSectionEntered = $true;
}
if ($_ -eq "" -and $accountSectionEntered) {
2023-07-02 22:35:40 +00:00
[string]::Join(
"`n",
@(
"0\$configName\$folderID\localPath=$localPath",
"0\$configName\$folderID\targetPath=$targetPath"));
}
$_;
} | Set-Content $this.GetNextcloudConfigFile();
2023-07-02 15:38:44 +00:00
Start-Process $nextcloudPath;
2023-07-02 13:44:47 +00:00
}
2023-06-22 20:58:54 +00:00
[void] Reboot() {
Write-Host "Restarting Computer...";
$this.RegisterReboot();
2023-06-22 20:58:54 +00:00
Restart-Computer;
2023-06-25 16:11:56 +00:00
exit;
2023-06-22 20:58:54 +00:00
}
}