2023-10-03 08:18:00 +00:00
|
|
|
#Function to check the connectivity
|
|
|
|
|
|
|
|
function Test-Network {
|
|
|
|
|
|
|
|
#Init
|
|
|
|
$timeout = 0
|
|
|
|
|
|
|
|
#Test connectivity during 30 min then timeout
|
|
|
|
Write-ToLog "Checking internet connection..." "Yellow"
|
|
|
|
|
2024-09-01 09:48:15 +00:00
|
|
|
try {
|
|
|
|
$NlaRegKey = "HKLM:\SYSTEM\CurrentControlSet\Services\NlaSvc\Parameters\Internet"
|
|
|
|
$ncsiHost = Get-ItemPropertyValue -Path $NlaRegKey -Name ActiveWebProbeHost
|
|
|
|
$ncsiPath = Get-ItemPropertyValue -Path $NlaRegKey -Name ActiveWebProbePath
|
|
|
|
$ncsiContent = Get-ItemPropertyValue -Path $NlaRegKey -Name ActiveWebProbeContent
|
2024-09-02 14:10:21 +00:00
|
|
|
}
|
|
|
|
catch {
|
2024-09-01 09:48:15 +00:00
|
|
|
$ncsiHost = "www.msftconnecttest.com"
|
|
|
|
$ncsiPath = "connecttest.txt"
|
|
|
|
$ncsiContent = "Microsoft Connect Test"
|
|
|
|
}
|
2024-09-02 14:10:21 +00:00
|
|
|
|
2024-09-01 09:48:15 +00:00
|
|
|
While ($timeout -lt 1800) {
|
2023-11-12 19:13:16 +00:00
|
|
|
try {
|
2024-09-04 20:28:02 +00:00
|
|
|
$ncsiResponse = Invoke-WebRequest -Uri "http://$($ncsiHost)/$($ncsiPath)" -UseBasicParsing -UserAgent ([Microsoft.PowerShell.Commands.PSUserAgent]::Chrome); # DevSkim: ignore DS137138 Insecure URL
|
2024-09-02 14:10:21 +00:00
|
|
|
}
|
|
|
|
catch {
|
2023-11-12 19:13:16 +00:00
|
|
|
$ncsiResponse = $false
|
|
|
|
}
|
|
|
|
|
|
|
|
if (($ncsiResponse) -and ($ncsiResponse.StatusCode -eq 200) -and ($ncsiResponse.content -eq $ncsiContent)) {
|
2023-10-03 08:18:00 +00:00
|
|
|
Write-ToLog "Connected !" "Green"
|
|
|
|
|
|
|
|
#Check for metered connection
|
|
|
|
[void][Windows.Networking.Connectivity.NetworkInformation, Windows, ContentType = WindowsRuntime]
|
|
|
|
$cost = [Windows.Networking.Connectivity.NetworkInformation]::GetInternetConnectionProfile().GetConnectionCost()
|
|
|
|
|
|
|
|
if ($cost.ApproachingDataLimit -or $cost.OverDataLimit -or $cost.Roaming -or $cost.BackgroundDataUsageRestricted -or ($cost.NetworkCostType -ne "Unrestricted")) {
|
|
|
|
|
|
|
|
Write-ToLog "Metered connection detected." "Yellow"
|
|
|
|
|
|
|
|
if ($WAUConfig.WAU_DoNotRunOnMetered -eq 1) {
|
|
|
|
|
|
|
|
Write-ToLog "WAU is configured to bypass update checking on metered connection"
|
|
|
|
return $false
|
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
|
|
|
|
Write-ToLog "WAU is configured to force update checking on metered connection"
|
|
|
|
return $true
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
|
|
|
|
return $true
|
|
|
|
|
2022-06-29 15:32:03 +00:00
|
|
|
}
|
2023-10-03 08:18:00 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
|
|
|
|
Start-Sleep 10
|
|
|
|
$timeout += 10
|
|
|
|
|
|
|
|
#Send Warning Notif if no connection for 5 min
|
|
|
|
if ($timeout -eq 300) {
|
|
|
|
#Log
|
|
|
|
Write-ToLog "Notify 'No connection' sent." "Yellow"
|
|
|
|
|
|
|
|
#Notif
|
|
|
|
$Title = $NotifLocale.local.outputs.output[0].title
|
|
|
|
$Message = $NotifLocale.local.outputs.output[0].message
|
|
|
|
$MessageType = "warning"
|
|
|
|
$Balise = "Connection"
|
|
|
|
Start-NotifTask -Title $Title -Message $Message -MessageType $MessageType -Balise $Balise
|
2022-03-14 13:55:02 +00:00
|
|
|
}
|
2023-10-03 08:18:00 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#Send Timeout Notif if no connection for 30 min
|
|
|
|
Write-ToLog "Timeout. No internet connection !" "Red"
|
|
|
|
|
|
|
|
#Notif
|
|
|
|
$Title = $NotifLocale.local.outputs.output[1].title
|
|
|
|
$Message = $NotifLocale.local.outputs.output[1].message
|
|
|
|
$MessageType = "error"
|
|
|
|
$Balise = "Connection"
|
|
|
|
Start-NotifTask -Title $Title -Message $Message -MessageType $MessageType -Balise $Balise
|
|
|
|
|
|
|
|
return $false
|
|
|
|
|
2022-10-24 09:51:26 +00:00
|
|
|
}
|