Created
February 19, 2022 15:46
-
-
Save busheezy/6f3074d8c8b97eb42f7215da0ec15e00 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
If (-NOT ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] "Administrator")) { | |
$arguments = "& '" + $myinvocation.mycommand.definition + "'" | |
Start-Process powershell -Verb runAs -ArgumentList $arguments | |
Break | |
} | |
$remoteport = bash.exe -c "ip addr | grep -Ee 'inet.*eth0'" | |
$found = $remoteport -match '\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}'; | |
if ($found) { | |
$remoteport = $matches[0]; | |
} | |
else { | |
Write-Output "IP address could not be found"; | |
exit; | |
} | |
$ports = @(22, 27015); | |
for ($i = 0; $i -lt $ports.length; $i++) { | |
$port = $ports[$i]; | |
Invoke-Expression "netsh interface portproxy delete v4tov4 listenport=$port"; | |
Invoke-Expression "netsh advfirewall firewall delete rule name=$port"; | |
Invoke-Expression "netsh interface portproxy add v4tov4 listenport=$port connectport=$port connectaddress=$remoteport"; | |
Invoke-Expression "netsh advfirewall firewall add rule name=$port dir=in action=allow protocol=TCP localport=$port"; | |
} | |
Invoke-Expression "netsh interface portproxy show v4tov4"; | |
bash.exe -c "sudo service ssh restart" |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment