mirror of
https://github.com/massgravel/massgrave.dev.git
synced 2024-11-23 23:10:55 +07:00
74 lines
3.5 KiB
PowerShell
74 lines
3.5 KiB
PowerShell
# Check massgrave.dev for more details
|
|
|
|
write-host
|
|
Write-Host "The current command (irm https://massgrave.dev/get | iex) will be retired in the future."
|
|
Write-Host -ForegroundColor Green "Use the new command (irm https://get.activated.win | iex) moving forward."
|
|
write-host
|
|
|
|
function CheckFile {
|
|
if (-not (Test-Path -Path $FilePath)) {
|
|
Check3rdAV
|
|
Write-Warning "Failed to create MAS file in temp folder, aborting!`n`nHelp - https://massgrave.dev/troubleshoot"
|
|
throw
|
|
}
|
|
}
|
|
|
|
function Check3rdAV {
|
|
$avList = Get-CimInstance -Namespace root\SecurityCenter2 -Class AntiVirusProduct | Where-Object { $_.displayName -notlike '*windows*' } | Select-Object -ExpandProperty displayName
|
|
if ($avList) {
|
|
Write-Warning "Installed 3rd party Antivirus might be blocking the script: $($avList -join ', ')"
|
|
}
|
|
}
|
|
|
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
|
$URLs = @(
|
|
'https://raw.githubusercontent.com/massgravel/Microsoft-Activation-Scripts/f1ddb83df092478741344fc55351a65cf6eeafd8/MAS/All-In-One-Version-KL/MAS_AIO.cmd',
|
|
'https://dev.azure.com/massgrave/Microsoft-Activation-Scripts/_apis/git/repositories/Microsoft-Activation-Scripts/items?path=/MAS/All-In-One-Version-KL/MAS_AIO.cmd&versionType=Commit&version=f1ddb83df092478741344fc55351a65cf6eeafd8',
|
|
'https://git.activated.win/massgrave/Microsoft-Activation-Scripts/raw/commit/f1ddb83df092478741344fc55351a65cf6eeafd8/MAS/All-In-One-Version-KL/MAS_AIO.cmd'
|
|
)
|
|
|
|
foreach ($URL in $URLs | Sort-Object { Get-Random }) {
|
|
try { $response = Invoke-WebRequest -Uri $URL -UseBasicParsing; break } catch {}
|
|
}
|
|
|
|
if (-not $response) {
|
|
Check3rdAV
|
|
Write-Warning "Failed to retrieve MAS from any of the available repositories, aborting!`n`nHelp - https://massgrave.dev/troubleshoot"
|
|
return
|
|
}
|
|
|
|
# Verify script integrity
|
|
$releaseHash = '2A0A5F9675BA93D11DF5EB531810F8097D1C13CE3A723FC2235A85127E86E172'
|
|
$stream = New-Object IO.MemoryStream
|
|
$writer = New-Object IO.StreamWriter $stream
|
|
$writer.Write($response)
|
|
$writer.Flush()
|
|
$stream.Position = 0
|
|
$hash = [BitConverter]::ToString([Security.Cryptography.SHA256]::Create().ComputeHash($stream)) -replace '-'
|
|
if ($hash -ne $releaseHash) {
|
|
Write-Warning "Hash ($hash) mismatch, aborting!`nReport this issue at https://massgrave.dev/troubleshoot"
|
|
$response = $null
|
|
return
|
|
}
|
|
|
|
# Check for AutoRun registry which may create issues with CMD
|
|
$paths = "HKCU:\SOFTWARE\Microsoft\Command Processor", "HKLM:\SOFTWARE\Microsoft\Command Processor"
|
|
foreach ($path in $paths) {
|
|
if (Get-ItemProperty -Path $path -Name "Autorun" -ErrorAction SilentlyContinue) {
|
|
Write-Warning "Autorun registry found, CMD may crash! `nManually copy-paste the below command to fix...`nRemove-ItemProperty -Path '$path' -Name 'Autorun'"
|
|
}
|
|
}
|
|
|
|
$rand = [Guid]::NewGuid().Guid
|
|
$isAdmin = [bool]([Security.Principal.WindowsIdentity]::GetCurrent().Groups -match 'S-1-5-32-544')
|
|
$FilePath = if ($isAdmin) { "$env:SystemRoot\Temp\MAS_$rand.cmd" } else { "$env:USERPROFILE\AppData\Local\Temp\MAS_$rand.cmd" }
|
|
Set-Content -Path $FilePath -Value "@::: $rand `r`n$response"
|
|
|
|
CheckFile
|
|
$env:ComSpec = "$env:SystemRoot\system32\cmd.exe"
|
|
Start-Process -FilePath $env:ComSpec -ArgumentList "/c """"$FilePath"" $args""" -Wait
|
|
|
|
CheckFile
|
|
$FilePaths = @("$env:SystemRoot\Temp\MAS*.cmd", "$env:USERPROFILE\AppData\Local\Temp\MAS*.cmd")
|
|
foreach ($FilePath in $FilePaths) { Get-Item $FilePath | Remove-Item }
|