|
|
|
@ -180,40 +180,55 @@ goto dk_done
@@ -180,40 +180,55 @@ goto dk_done
|
|
|
|
|
|
|
|
|
|
::======================================================================================================================================== |
|
|
|
|
|
|
|
|
|
:: Elevate script as admin and pass arguments and preventing loop |
|
|
|
|
|
|
|
|
|
%nul1% fltmc || ( |
|
|
|
|
if not defined _elev %psc% "start cmd.exe -arg '/c \"!_PSarg!\"' -verb runas" && exit /b |
|
|
|
|
%eline% |
|
|
|
|
echo This script needs admin rights. |
|
|
|
|
echo Right click on this script and select 'Run as administrator'. |
|
|
|
|
goto dk_done |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
::======================================================================================================================================== |
|
|
|
|
|
|
|
|
|
:: Check PowerShell |
|
|
|
|
|
|
|
|
|
REM :PStest: $ExecutionContext.SessionState.LanguageMode :PStest: |
|
|
|
|
::pstst $ExecutionContext.SessionState.LanguageMode :pstst |
|
|
|
|
|
|
|
|
|
for /f "delims=" %%a in ('cmd /c "%psc% ""if ($PSVersionTable.PSEdition -ne 'Core') {$f=[io.file]::ReadAllText('!_batp!') -split ':pstst';iex ($f[1])}""" %nul6%') do (set tstresult=%%a) |
|
|
|
|
|
|
|
|
|
cmd /c "%psc% "$f=[io.file]::ReadAllText('!_batp!') -split ':PStest:\s*';iex ($f[1])"" | find /i "FullLanguage" %nul1% || ( |
|
|
|
|
if /i not "%tstresult%"=="FullLanguage" ( |
|
|
|
|
%eline% |
|
|
|
|
cmd /c "%psc% "$ExecutionContext.SessionState.LanguageMode"" |
|
|
|
|
echo: |
|
|
|
|
cmd /c "%psc% "$ExecutionContext.SessionState.LanguageMode"" | find /i "FullLanguage" %nul1% && ( |
|
|
|
|
echo Failed to run Powershell command but Powershell is working. |
|
|
|
|
echo: |
|
|
|
|
cmd /c "%psc% ""$av = Get-WmiObject -Namespace root\SecurityCenter2 -Class AntiVirusProduct; $n = @(); foreach ($i in $av) { if ($i.displayName -notlike '*windows*') { $n += $i.displayName } }; if ($n) { Write-Host ('Installed 3rd party Antivirus might be blocking the script - ' + ($n -join ', ')) -ForegroundColor White -BackgroundColor Blue }""" |
|
|
|
|
echo: |
|
|
|
|
set fixes=%fixes% %mas%troubleshoot |
|
|
|
|
call :dk_color2 %Blue% "Help - " %_Yellow% " %mas%troubleshoot" |
|
|
|
|
) || ( |
|
|
|
|
echo PowerShell is not working. Aborting... |
|
|
|
|
echo %tstresult% |
|
|
|
|
cmd /c "%psc% $ExecutionContext.SessionState.LanguageMode" |
|
|
|
|
|
|
|
|
|
REM check LanguageMode |
|
|
|
|
|
|
|
|
|
cmd /c "%psc% "$ExecutionContext.SessionState.LanguageMode"" | findstr /i "ConstrainedLanguage RestrictedLanguage NoLanguage" %nul1% && ( |
|
|
|
|
%eline% |
|
|
|
|
echo FullLanguage mode not found in PowerShell. Aborting... |
|
|
|
|
echo If you have applied restrictions on Powershell then undo those changes. |
|
|
|
|
echo: |
|
|
|
|
set fixes=%fixes% %mas%fix_powershell |
|
|
|
|
call :dk_color2 %Blue% "Help - " %_Yellow% " %mas%fix_powershell" |
|
|
|
|
) |
|
|
|
|
goto dk_done |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
::======================================================================================================================================== |
|
|
|
|
REM check Powershell core version |
|
|
|
|
|
|
|
|
|
:: Elevate script as admin and pass arguments and preventing loop |
|
|
|
|
cmd /c "%psc% "$PSVersionTable.PSEdition"" | find /i "Core" %nul1% && ( |
|
|
|
|
echo Windows Powershell is needed for MAS but it seems to be replaced with Powershell core. Aborting... |
|
|
|
|
goto dk_done |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
%nul1% fltmc || ( |
|
|
|
|
if not defined _elev %psc% "start cmd.exe -arg '/c \"!_PSarg!\"' -verb runas" && exit /b |
|
|
|
|
%eline% |
|
|
|
|
echo This script needs admin rights. |
|
|
|
|
echo Right click on this script and select 'Run as administrator'. |
|
|
|
|
REM check antivirus and other errors |
|
|
|
|
|
|
|
|
|
echo PowerShell is not working properly. Aborting... |
|
|
|
|
cmd /c "%psc% ""$av = Get-WmiObject -Namespace root\SecurityCenter2 -Class AntiVirusProduct; $n = @(); foreach ($i in $av) { if ($i.displayName -notlike '*windows*') { $n += $i.displayName } }; if ($n) { Write-Host ('Installed 3rd party Antivirus might be blocking the script - ' + ($n -join ', ')) -ForegroundColor White -BackgroundColor Blue }""" |
|
|
|
|
echo: |
|
|
|
|
set fixes=%fixes% %mas%troubleshoot |
|
|
|
|
call :dk_color2 %Blue% "Help - " %_Yellow% " %mas%troubleshoot" |
|
|
|
|
goto dk_done |
|
|
|
|
) |
|
|
|
|
|
|
|
|
@ -265,12 +280,18 @@ set "d4=$k=$t.CreateType(); $b=$k::SetConsoleMode($k::GetStdHandle(-10), 0x0080)
@@ -265,12 +280,18 @@ set "d4=$k=$t.CreateType(); $b=$k::SetConsoleMode($k::GetStdHandle(-10), 0x0080)
|
|
|
|
|
|
|
|
|
|
set -= |
|
|
|
|
set old= |
|
|
|
|
set pingp= |
|
|
|
|
set upver=%masver:.=% |
|
|
|
|
|
|
|
|
|
for /f "delims=[] tokens=2" %%# in ('ping -4 -n 1 activ%-%ated.win') do ( |
|
|
|
|
if not "%%#"=="" set old=1 |
|
|
|
|
for /f "delims=[] tokens=2" %%# in ('ping -4 -n 1 updatecheck%upver%.activ%-%ated.win') do ( |
|
|
|
|
if not "%%#"=="" set old= |
|
|
|
|
for %%A in ( |
|
|
|
|
activ%-%ated.win |
|
|
|
|
mass%-%grave.dev |
|
|
|
|
) do if not defined pingp ( |
|
|
|
|
for /f "delims=[] tokens=2" %%B in ('ping -n 1 %%A') do ( |
|
|
|
|
if not "%%B"=="" (set old=1& set pingp=1) |
|
|
|
|
for /f "delims=[] tokens=2" %%C in ('ping -n 1 updatecheck%upver%.%%A') do ( |
|
|
|
|
if not "%%C"=="" set old= |
|
|
|
|
) |
|
|
|
|
) |
|
|
|
|
) |
|
|
|
|
|
|
|
|
@ -4037,9 +4058,13 @@ REM Windows8.1
@@ -4037,9 +4058,13 @@ REM Windows8.1
|
|
|
|
|
REM WindowsServer2012/2012R2 |
|
|
|
|
55b1dd2d-2209-4ea0-a805-06298bad25b3_Server-ESU-Year3[1-3y]_-ServerDatacenter-ServerDatacenterCore-ServerDatacenterV-ServerDatacenterVCore-ServerStandard-ServerStandardCore-ServerStandardV-ServerStandardVCore- |
|
|
|
|
REM Windows10 |
|
|
|
|
83d49986-add3-41d7-ba33-87c7bfb5c0fb_Client-ESU-Year3[1-3y]_-Education-EducationN-Enterprise-EnterpriseN-Professional-ProfessionalEducation-ProfessionalEducationN-ProfessionalN-ProfessionalWorkstation-ProfessionalWorkstationN-ServerRdsh- |
|
|
|
|
f520e45e-7413-4a34-a497-d2765967d094_Client-ESU-Year1_-Education-EducationN-Enterprise-EnterpriseN-Professional-ProfessionalEducation-ProfessionalEducationN-ProfessionalN-ProfessionalWorkstation-ProfessionalWorkstationN-ServerRdsh- |
|
|
|
|
1043add5-23b1-4afb-9a0f-64343c8f3f8d_Client-ESU-Year2_-Education-EducationN-Enterprise-EnterpriseN-Professional-ProfessionalEducation-ProfessionalEducationN-ProfessionalN-ProfessionalWorkstation-ProfessionalWorkstationN-ServerRdsh- |
|
|
|
|
83d49986-add3-41d7-ba33-87c7bfb5c0fb_Client-ESU-Year3_-Education-EducationN-Enterprise-EnterpriseN-Professional-ProfessionalEducation-ProfessionalEducationN-ProfessionalN-ProfessionalWorkstation-ProfessionalWorkstationN-ServerRdsh- |
|
|
|
|
0b533b5e-08b6-44f9-b885-c2de291ba456_Client-ESU-Year6[4-6y]_-Education-EducationN-Enterprise-EnterpriseN-Professional-ProfessionalEducation-ProfessionalEducationN-ProfessionalN-ProfessionalWorkstation-ProfessionalWorkstationN-ServerRdsh- |
|
|
|
|
4dac5a0c-5709-4595-a32c-14a56a4a6b31_Client-IoT-ESU-Year3[1-3y]_-IoTEnterprise- |
|
|
|
|
b8527af1-5389-447c-9a88-2d1691ea33d3_Client-IoT-ESU-Year1_-IoTEnterprise- |
|
|
|
|
7b76ee02-0a75-4f08-85d5-bd0feadad0c0_Client-IoT-ESU-Year2_-IoTEnterprise- |
|
|
|
|
4dac5a0c-5709-4595-a32c-14a56a4a6b31_Client-IoT-ESU-Year3_-IoTEnterprise- |
|
|
|
|
f69e2d51-3bbd-4ddf-8da7-a145e9dca597_Client-IoT-ESU-Year6[4-6y]_-IoTEnterprise- |
|
|
|
|
) do ( |
|
|
|
|
for /f "tokens=1-3 delims=_" %%A in ("%%#") do ( |
|
|
|
@ -4740,8 +4765,7 @@ mode 100, 30
@@ -4740,8 +4765,7 @@ mode 100, 30
|
|
|
|
|
title Remove TSforge Activation %masver% |
|
|
|
|
|
|
|
|
|
echo: |
|
|
|
|
echo TSforge activation doesn't modify any Windows component. |
|
|
|
|
echo TSforge activation doesn't install any new file in the system. |
|
|
|
|
echo TSforge activation doesn't modify any Windows components and doesn't install any new files. |
|
|
|
|
echo: |
|
|
|
|
echo Instead, it appends data to one of data files used by Software Protection Platform. |
|
|
|
|
echo: |
|
|
|
|