Skip to content

Instantly share code, notes, and snippets.

@rcdelacruz
Forked from xmeng1/wsl2-network.ps1
Created April 27, 2024 10:16
Show Gist options
  • Select an option

  • Save rcdelacruz/d17c7f04dd4477c2b1d3a24797dde6e0 to your computer and use it in GitHub Desktop.

Select an option

Save rcdelacruz/d17c7f04dd4477c2b1d3a24797dde6e0 to your computer and use it in GitHub Desktop.

Revisions

  1. @xmeng1 xmeng1 created this gist Jul 14, 2019.
    34 changes: 34 additions & 0 deletions wsl2-network.ps1
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,34 @@
    $remoteport = bash.exe -c "ifconfig eth0 | grep 'inet '"
    $found = $remoteport -match '\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}';

    if( $found ){
    $remoteport = $matches[0];
    } else{
    echo "The Script Exited, the ip address of WSL 2 cannot be found";
    exit;
    }

    #[Ports]

    #All the ports you want to forward separated by coma
    $ports=@(80,443,10000,3000,5000);


    #[Static ip]
    #You can change the addr to your ip config to listen to a specific address
    $addr='0.0.0.0';
    $ports_a = $ports -join ",";


    #Remove Firewall Exception Rules
    iex "Remove-NetFireWallRule -DisplayName 'WSL 2 Firewall Unlock' ";

    #adding Exception Rules for inbound and outbound Rules
    iex "New-NetFireWallRule -DisplayName 'WSL 2 Firewall Unlock' -Direction Outbound -LocalPort $ports_a -Action Allow -Protocol TCP";
    iex "New-NetFireWallRule -DisplayName 'WSL 2 Firewall Unlock' -Direction Inbound -LocalPort $ports_a -Action Allow -Protocol TCP";

    for( $i = 0; $i -lt $ports.length; $i++ ){
    $port = $ports[$i];
    iex "netsh interface portproxy delete v4tov4 listenport=$port listenaddress=$addr";
    iex "netsh interface portproxy add v4tov4 listenport=$port listenaddress=$addr connectport=$port connectaddress=$remoteport";
    }