// +build windows /* Copyright 2017 The Kubernetes Authors. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ package preflight import ( "os/user" "github.com/pkg/errors" ) // The "Well-known SID" of Administrator group // https://support.microsoft.com/en-us/help/243330/well-known-security-identifiers-in-windows-operating-systems const administratorSID = "S-1-5-32-544" // Check validates if a user has elevated (administrator) privileges. func (ipuc IsPrivilegedUserCheck) Check() (warnings, errorList []error) { errorList = []error{} currUser, err := user.Current() if err != nil { errorList = append(errorList, errors.New("cannot get current user")) return nil, errorList } groupIds, err := currUser.GroupIds() if err != nil { errorList = append(errorList, errors.New("cannot get group IDs for current user")) return nil, errorList } for _, sid := range groupIds { if sid == administratorSID { return nil, errorList } } errorList = append(errorList, errors.New("user is not running as administrator")) return nil, errorList } // Check validates if Docker is setup to use systemd as the cgroup driver. // No-op for Windows. func (idsc IsDockerSystemdCheck) Check() (warnings, errorList []error) { return nil, nil } // Check determines if IPVS proxier can be used or not // No-op for Windows. func (ipvspc IPVSProxierCheck) Check() (warnings, errors []error) { return nil, nil }