9bcb3cba83
- pkg/useragent - pkg/units - pkg/ulimit - pkg/truncindex - pkg/timeoutconn - pkg/term - pkg/tarsum - pkg/tailfile - pkg/systemd - pkg/stringutils - pkg/stringid - pkg/streamformatter - pkg/sockets - pkg/signal - pkg/proxy - pkg/progressreader - pkg/pools - pkg/plugins - pkg/pidfile - pkg/parsers - pkg/parsers/filters - pkg/parsers/kernel - pkg/parsers/operatingsystem Signed-off-by: Vincent Demeester <vincent@sbr.pm>
49 lines
1.1 KiB
Go
49 lines
1.1 KiB
Go
package operatingsystem
|
|
|
|
import (
|
|
"syscall"
|
|
"unsafe"
|
|
)
|
|
|
|
// See https://code.google.com/p/go/source/browse/src/pkg/mime/type_windows.go?r=d14520ac25bf6940785aabb71f5be453a286f58c
|
|
// for a similar sample
|
|
|
|
// GetOperatingSystem gets the name of the current operating system.
|
|
func GetOperatingSystem() (string, error) {
|
|
|
|
var h syscall.Handle
|
|
|
|
// Default return value
|
|
ret := "Unknown Operating System"
|
|
|
|
if err := syscall.RegOpenKeyEx(syscall.HKEY_LOCAL_MACHINE,
|
|
syscall.StringToUTF16Ptr(`SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\`),
|
|
0,
|
|
syscall.KEY_READ,
|
|
&h); err != nil {
|
|
return ret, err
|
|
}
|
|
defer syscall.RegCloseKey(h)
|
|
|
|
var buf [1 << 10]uint16
|
|
var typ uint32
|
|
n := uint32(len(buf) * 2) // api expects array of bytes, not uint16
|
|
|
|
if err := syscall.RegQueryValueEx(h,
|
|
syscall.StringToUTF16Ptr("ProductName"),
|
|
nil,
|
|
&typ,
|
|
(*byte)(unsafe.Pointer(&buf[0])),
|
|
&n); err != nil {
|
|
return ret, err
|
|
}
|
|
ret = syscall.UTF16ToString(buf[:])
|
|
|
|
return ret, nil
|
|
}
|
|
|
|
// IsContainerized returns true if we are running inside a container.
|
|
// No-op on Windows, always returns false.
|
|
func IsContainerized() (bool, error) {
|
|
return false, nil
|
|
}
|