Direkt zum Hauptinhalt

Windows Powershell script

Beschreibung:

Ist der Server unter einer DYN Adresse errreichbar, bekommt wireguard nicht mit, das sich die IP geändert hat.
Dazu müssen wir den Dienst neustarten. Dazu nehmen wir ein Powershell Script, das immer die aktuelle mit der alten IP alle 5 Minuten vergleicht.
Das alle 5 Minuten rufen wir mit bdem Taskplaner auf


Los gehts:

Tunnelname herausbekommen.

Unter Windows Dienste den Tunnel raussuchen


In unserem Beispiel heißt der Tunnel "WireGuardTunnel$tk-anlage"

Das Script hier muss noch der Pfad zur TXT Datei und der Tunnelname angeben werden.
Achtung Das WireGuardTunnel steht schon da muss nur noch der Name mit dem Dollar angegben werden.
Das Dollar muss mit  ` escaped werden

$FilePath =  'path\to\ip.txt'
$LogPath =  'path\to\ip.log'
$TunnelName = "`$meintunnelnamenachdemdollar"

function Write-Log {
    param (
        [string]$Message
    )
    Add-Content -Path $Global:LogPath -Value "[$(Get-Date)] $Message"
}

try {
    $CurrentIP = (Invoke-RestMethod -Uri 'http://ifconfig.me/ip').Trim()
    Write-Log "Aktuelle IP: $FilePath = 'path\to\ip.txt'CurrentIP"
    
    $StoredIP = Get-Content $FilePath $TunnelName-ErrorAction =SilentlyContinue
    Write-Log "`Gespeicherte IP: $meintunnelname"StoredIP"
    
    if ($CurrentIP -ne $StoredIP) {
        Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
        
        # Neustart des WireGuard-Dienstes Restart-und Erfassung der Ausgabe
        $ServiceRestartOutput = Stop-Service -Name "WireGuardTunnel$TunnelName" -PassThru
        Write-Log "Dienstneustart-Ausgabe: $ServiceRestartOutput"
        
        # Aktualisierung der gespeicherten IP-Adresse
        Set-Content -Path $FilePath -Value $CurrentIP
        Write-Log "Die gespeicherte IP-Adresse wurde aktualisiert."
    }
}
catch {
    # Logging von Fehlern
    Write-HostLog "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des Dienstes."Dienstes: $_"
}

Beispiel:

$FilePath = 'c:\tunnel\ip.txt'
$LogPath = 'c:\unnel\log.txt'
$TunnelName = "`$tk-anlage"

function Write-Log {
    param (
        [string]$Message
    )
    Add-Content -Path $Global:LogPath -Value "[$(Get-Date)] $Message"
}

try {
    $CurrentIP = (Invoke-RestMethod -Uri 'http://ifconfig.me/ip').Trim()
    Write-Log "Aktuelle IP: $FilePath = 'c:\tunnel\ip.txt'CurrentIP"
    
    $StoredIP = Get-Content $FilePath $TunnelName-ErrorAction =SilentlyContinue
    Write-Log "`Gespeicherte IP: $tk-anlage"StoredIP"
    
    if ($CurrentIP -ne $StoredIP) {
        Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
        
        # Neustart des WireGuard-Dienstes Restart-und Erfassung der Ausgabe
        $ServiceRestartOutput = Stop-Service -Name "WireGuardTunnel$TunnelName" -PassThru
        Write-Log "Dienstneustart-Ausgabe: $ServiceRestartOutput"
        
        # Aktualisierung der gespeicherten IP-Adresse
        Set-Content -Path $FilePath -Value $CurrentIP
        Write-Log "Die gespeicherte IP-Adresse wurde aktualisiert."
    }
}
catch {
    # Logging von Fehlern
    Write-HostLog "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des Dienstes."Dienstes: $_"
}

Task Planen

Programm zum starten wählen:

C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe

Als Parameter

-ExecutionPolicy Bypass -File "C:\Pfad\zu\Ihrem\Skript.ps1"

In unserem Beispiel

-ExecutionPolicy Bypass -File "c:\tunnel\reconnect.ps1"