Compare commits

...

8 Commits

Author SHA1 Message Date
92828931c0 Detect Sysnative path 2025-08-11 05:03:37 +05:30
dd429f89fa 3.5 2025-08-11 02:46:05 +05:30
bda8e25dc6 skip cmd relaunch on PS 2.0 2025-08-11 01:41:53 +05:30
66b1789202 Fix start-process and write-progress on PS 2.0 2025-08-10 22:22:43 +05:30
836a6d277b Update print info, different progress bar, and add -verb runas 2025-08-10 06:57:10 +05:30
1d4c5a232a Fix script block, print homepage info 2025-08-10 04:24:34 +05:30
8de888f52f Revert "Add script block"
This reverts commit 8dafebad65.
2025-08-10 03:57:43 +05:30
8dafebad65 Add script block 2025-08-10 01:50:33 +05:30

View File

@@ -1,122 +1,137 @@
# This script is hosted on <b>https://get.activated.win</b> for <b>https://massgrave.dev</b><hr><pre> # This script is hosted on <b>https://get.activated.win</b> for <b>https://massgrave.dev</b><hr><pre>
$psv = (Get-Host).Version.Major if (-not $args) {
$troubleshoot = 'https://massgrave.dev/troubleshoot' Write-Host ''
Write-Host 'Need help? Check our homepage: ' -NoNewline
if ($ExecutionContext.SessionState.LanguageMode.value__ -ne 0) { Write-Host 'https://massgrave.dev' -ForegroundColor Green
$ExecutionContext.SessionState.LanguageMode Write-Host ''
Write-Host "PowerShell is not running in Full Language Mode."
Write-Host "Help - https://gravesoft.dev/fix_powershell" -ForegroundColor White -BackgroundColor Blue
return
} }
try { & {
[void][System.AppDomain]::CurrentDomain.GetAssemblies(); [void][System.Math]::Sqrt(144) $psv = (Get-Host).Version.Major
} $troubleshoot = 'https://massgrave.dev/troubleshoot'
catch {
Write-Host "Error: $($_.Exception.Message)" -ForegroundColor Red
Write-Host "Powershell failed to load .NET command."
Write-Host "Help - https://gravesoft.dev/in-place_repair_upgrade" -ForegroundColor White -BackgroundColor Blue
return
}
function Check3rdAV { if ($ExecutionContext.SessionState.LanguageMode.value__ -ne 0) {
$cmd = if ($psv -ge 3) { 'Get-CimInstance' } else { 'Get-WmiObject' } $ExecutionContext.SessionState.LanguageMode
$avList = & $cmd -Namespace root\SecurityCenter2 -Class AntiVirusProduct | Where-Object { $_.displayName -notlike '*windows*' } | Select-Object -ExpandProperty displayName Write-Host "PowerShell is not running in Full Language Mode."
Write-Host "Help - https://gravesoft.dev/fix_powershell" -ForegroundColor White -BackgroundColor Blue
if ($avList) { return
Write-Host '3rd party Antivirus might be blocking the script - ' -ForegroundColor White -BackgroundColor Blue -NoNewline
Write-Host " $($avList -join ', ')" -ForegroundColor DarkRed -BackgroundColor White
} }
}
function CheckFile {
param ([string]$FilePath)
if (-not (Test-Path $FilePath)) {
Check3rdAV
Write-Host "Failed to create MAS file in temp folder, aborting!"
Write-Host "Help - $troubleshoot" -ForegroundColor White -BackgroundColor Blue
throw
}
}
try { [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 } catch {}
$URLs = @(
'https://raw.githubusercontent.com/massgravel/Microsoft-Activation-Scripts/67abcd0c8925832fcf4365b9cf3706ab6fbf8571/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=67abcd0c8925832fcf4365b9cf3706ab6fbf8571',
'https://git.activated.win/massgrave/Microsoft-Activation-Scripts/raw/commit/67abcd0c8925832fcf4365b9cf3706ab6fbf8571/MAS/All-In-One-Version-KL/MAS_AIO.cmd'
)
$errors = @()
foreach ($URL in $URLs | Sort-Object { Get-Random }) {
try { try {
if ($psv -ge 3) { [void][System.AppDomain]::CurrentDomain.GetAssemblies(); [void][System.Math]::Sqrt(144)
$response = Invoke-WebRequest -Uri $URL -UseBasicParsing
}
else {
$w = New-Object Net.WebClient
$response = $w.DownloadString($URL)
}
break
} }
catch { catch {
$errors += $_ Write-Host "Error: $($_.Exception.Message)" -ForegroundColor Red
Write-Host "Powershell failed to load .NET command."
Write-Host "Help - https://gravesoft.dev/in-place_repair_upgrade" -ForegroundColor White -BackgroundColor Blue
return
} }
}
if (-not $response) { function Check3rdAV {
Check3rdAV $cmd = if ($psv -ge 3) { 'Get-CimInstance' } else { 'Get-WmiObject' }
foreach ($err in $errors) { $avList = & $cmd -Namespace root\SecurityCenter2 -Class AntiVirusProduct | Where-Object { $_.displayName -notlike '*windows*' } | Select-Object -ExpandProperty displayName
Write-Host "Error: $($err.Exception.Message)" -ForegroundColor Red
if ($avList) {
Write-Host '3rd party Antivirus might be blocking the script - ' -ForegroundColor White -BackgroundColor Blue -NoNewline
Write-Host " $($avList -join ', ')" -ForegroundColor DarkRed -BackgroundColor White
}
} }
Write-Host "Failed to retrieve MAS from any of the available repositories, aborting!"
Write-Host "Check if antivirus or firewall is blocking the connection."
Write-Host "Help - $troubleshoot" -ForegroundColor White -BackgroundColor Blue
return
}
# Verify script integrity function CheckFile {
$releaseHash = 'EF2F705B9E8BE2816598E2E8B70BADB200733F2287B917D6C9666D95C63AFBF9' param ([string]$FilePath)
$stream = New-Object IO.MemoryStream if (-not (Test-Path $FilePath)) {
$writer = New-Object IO.StreamWriter $stream Check3rdAV
$writer.Write($response) Write-Host "Failed to create MAS file in temp folder, aborting!"
$writer.Flush() Write-Host "Help - $troubleshoot" -ForegroundColor White -BackgroundColor Blue
$stream.Position = 0 throw
$hash = [BitConverter]::ToString([Security.Cryptography.SHA256]::Create().ComputeHash($stream)) -replace '-' }
if ($hash -ne $releaseHash) { }
Write-Warning "Hash ($hash) mismatch, aborting!`nReport this issue at $troubleshoot"
$response = $null
return
}
# Check for AutoRun registry which may create issues with CMD try { [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 } catch {}
$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 $URLs = @(
$isAdmin = [bool]([Security.Principal.WindowsIdentity]::GetCurrent().Groups -match 'S-1-5-32-544') 'https://raw.githubusercontent.com/massgravel/Microsoft-Activation-Scripts/3917497c826685ffc6f3d025397e5c8c4f7fa744/MAS/All-In-One-Version-KL/MAS_AIO.cmd',
$FilePath = if ($isAdmin) { "$env:SystemRoot\Temp\MAS_$rand.cmd" } else { "$env:USERPROFILE\AppData\Local\Temp\MAS_$rand.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=3917497c826685ffc6f3d025397e5c8c4f7fa744',
Set-Content -Path $FilePath -Value "@::: $rand `r`n$response" 'https://git.activated.win/massgrave/Microsoft-Activation-Scripts/raw/commit/3917497c826685ffc6f3d025397e5c8c4f7fa744/MAS/All-In-One-Version-KL/MAS_AIO.cmd'
CheckFile $FilePath )
Write-Progress -Activity "Downloading..." -Status "Please wait"
$errors = @()
foreach ($URL in $URLs | Sort-Object { Get-Random }) {
try {
if ($psv -ge 3) {
$response = Invoke-RestMethod $URL
}
else {
$w = New-Object Net.WebClient
$response = $w.DownloadString($URL)
}
break
}
catch {
$errors += $_
}
}
Write-Progress -Activity "Downloading..." -Status "Done" -Completed
$env:ComSpec = "$env:SystemRoot\system32\cmd.exe" if (-not $response) {
$chkcmd = & $env:ComSpec /c "echo CMD is working" Check3rdAV
if ($chkcmd -notcontains "CMD is working") { foreach ($err in $errors) {
Write-Warning "cmd.exe is not working.`nReport this issue at $troubleshoot" Write-Host "Error: $($err.Exception.Message)" -ForegroundColor Red
} }
saps -FilePath $env:ComSpec -ArgumentList "/c """"$FilePath"" $args""" -Wait Write-Host "Failed to retrieve MAS from any of the available repositories, aborting!"
CheckFile $FilePath Write-Host "Check if antivirus or firewall is blocking the connection."
Write-Host "Help - $troubleshoot" -ForegroundColor White -BackgroundColor Blue
return
}
if ($psv -lt 3) { # Verify script integrity
write-host "" $releaseHash = '4A0123C97E7859679DD49F22D5948FD77A775CC526B9E07797FC293C6C7731BC'
write-host "Press any key to exit when process is done..." $stream = New-Object IO.MemoryStream
[void][System.Console]::ReadKey($true) $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 $troubleshoot"
$response = $null
return
}
$FilePaths = @("$env:SystemRoot\Temp\MAS*.cmd", "$env:USERPROFILE\AppData\Local\Temp\MAS*.cmd") # Check for AutoRun registry which may create issues with CMD
foreach ($FilePath in $FilePaths) { Get-Item $FilePath -ErrorAction SilentlyContinue | Remove-Item } $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 $FilePath
$env:ComSpec = "$env:SystemRoot\system32\cmd.exe"
$chkcmd = & $env:ComSpec /c "echo CMD is working"
if ($chkcmd -notcontains "CMD is working") {
Write-Warning "cmd.exe is not working.`nReport this issue at $troubleshoot"
}
if ($psv -lt 3) {
if (Test-Path "$env:SystemRoot\Sysnative") {
Write-Warning "Command is running with x86 Powershell, run it with x64 Powershell instead..."
return
}
$p = saps -FilePath $env:ComSpec -ArgumentList "/c """"$FilePath"" -el -qedit $args""" -Verb RunAs -PassThru
$p.WaitForExit()
}
else {
saps -FilePath $env:ComSpec -ArgumentList "/c """"$FilePath"" -el $args""" -Wait -Verb RunAs
}
CheckFile $FilePath
$FilePaths = @("$env:SystemRoot\Temp\MAS*.cmd", "$env:USERPROFILE\AppData\Local\Temp\MAS*.cmd")
foreach ($FilePath in $FilePaths) { Get-Item $FilePath -ErrorAction SilentlyContinue | Remove-Item }
} @args