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, zur Log Datei und der Tunnelname angeben werden.
Das WireGuardTunnel steht schon da, es muss nur noch der Name mit dem Dollar angegben werden.
Das Dollar muss mit ` escaped werden. : Beispiel : $TunnelName = "`$tk-anlage"
$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: $CurrentIP"
$StoredIP = Get-Content $FilePath -ErrorAction SilentlyContinue
Write-Log "Gespeicherte IP: $StoredIP"
if ($CurrentIP -ne $StoredIP) {
Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
# Neustart des WireGuard-Dienstes und Erfassung der Ausgabe
$ServiceRestartOutput = Restart-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-Log "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des 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: $CurrentIP"
$StoredIP = Get-Content $FilePath -ErrorAction SilentlyContinue
Write-Log "Gespeicherte IP: $StoredIP"
if ($CurrentIP -ne $StoredIP) {
Write-Log "IP-Adresse hat sich geändert. Neustart des Dienstes..."
# Neustart des WireGuard-Dienstes und Erfassung der Ausgabe
$ServiceRestartOutput = Restart-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-Log "Es gab einen Fehler beim Abrufen der aktuellen IP-Adresse oder beim Neustart des 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"
Nun in den erweitertet Eigenschaften jeden Tag um 00:00 UHR und Ausführung alle 5 Minuten auswählen und Ausführung alle 1 Tag!
Den Haken bei Aktiviert nicht vergessen!
Nun noch mit Windows 10 auswählen und unabhängig von der Benutzeranmeldung ausführen auswählen.
Dann noch mit höchsten Privilegien ausführen.
Fertig.