Skip to content

Commit

Permalink
Disable PowerShell profile and simplify fingerprinting link speed on …
Browse files Browse the repository at this point in the history
…Windows (#11183)
  • Loading branch information
lgfa29 committed Nov 15, 2021
1 parent bdcd280 commit 7b8c455
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 62 deletions.
3 changes: 3 additions & 0 deletions .changelog/11183.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:bug
client: Fixed a bug where network speed fingerprint could fail on Windows
```
34 changes: 6 additions & 28 deletions client/fingerprint/network_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,44 +9,22 @@ import (

// linkSpeed returns link speed in Mb/s, or 0 when unable to determine it.
func (f *NetworkFingerprint) linkSpeed(device string) int {
command := fmt.Sprintf("Get-NetAdapter -IncludeHidden | Where name -eq '%s' | Select -ExpandProperty LinkSpeed", device)
command := fmt.Sprintf("Get-NetAdapter -Name '%s' -ErrorAction Ignore | Select-Object -ExpandProperty 'Speed'", device)
path := "powershell.exe"
outBytes, err := exec.Command(path, command).Output()
powershellParams := "-NoProfile"

outBytes, err := exec.Command(path, powershellParams, command).Output()
if err != nil {
f.logger.Warn("failed to detect link speed", "path", path, "command", command, "error", err)
return 0
}

output := strings.TrimSpace(string(outBytes))

return f.parseLinkSpeed(output)
}

func (f *NetworkFingerprint) parseLinkSpeed(commandOutput string) int {
args := strings.Split(commandOutput, " ")
if len(args) != 2 {
f.logger.Warn("couldn't split LinkSpeed output", "output", commandOutput)
return 0
}

unit := strings.Replace(args[1], "\r\n", "", -1)
value, err := strconv.Atoi(args[0])
value, err := strconv.Atoi(output)
if err != nil {
f.logger.Warn("unable to parse LinkSpeed value", "value", commandOutput)
f.logger.Warn("unable to parse Speed value", "device", device, "value", output, "error", err)
return 0
}

switch unit {
case "Mbps":
return value
case "Kbps":
return value / 1000
case "Gbps":
return value * 1000
case "bps":
return value / 1000000
}

return 0
return value / 1000000
}
34 changes: 0 additions & 34 deletions client/fingerprint/network_windows_test.go

This file was deleted.

0 comments on commit 7b8c455

Please sign in to comment.