Files
yggdrasil-go/cmd/yggdrasil/chuser_unix.go
state-plumber aaf263957b Change ownership of admin socket before dropping permissions (#1336)
This is to allow access to the socket by members of the group that
permissions are dropped to.
2026-05-12 21:39:55 +01:00

75 lines
1.5 KiB
Go

//go:build aix || darwin || dragonfly || freebsd || linux || netbsd || openbsd || solaris
package main
import (
"fmt"
"net/url"
"os"
"os/user"
"strconv"
"strings"
"golang.org/x/sys/unix"
)
func chuser(input, adminSockUrl string) error {
givenUser, givenGroup, _ := strings.Cut(input, ":")
if givenUser == "" {
return fmt.Errorf("user is empty")
}
if strings.Contains(input, ":") && givenGroup == "" {
return fmt.Errorf("group is empty")
}
var (
err error
usr *user.User
grp *user.Group
uid, gid int
)
if usr, err = user.LookupId(givenUser); err != nil {
if usr, err = user.Lookup(givenUser); err != nil {
return err
}
}
if uid, err = strconv.Atoi(usr.Uid); err != nil {
return err
}
if givenGroup != "" {
if grp, err = user.LookupGroupId(givenGroup); err != nil {
if grp, err = user.LookupGroup(givenGroup); err != nil {
return err
}
}
gid, _ = strconv.Atoi(grp.Gid)
} else {
gid, _ = strconv.Atoi(usr.Gid)
}
if adminSockUrl != "" {
u, err := url.Parse(adminSockUrl)
if err == nil && u.Scheme == "unix" {
err = os.Chown(u.Path, uid, gid)
}
if err != nil {
return fmt.Errorf("chown %s %d:%d: %v", adminSockUrl, uid, gid, err)
}
}
if err := unix.Setgroups([]int{gid}); err != nil {
return fmt.Errorf("setgroups: %d: %v", gid, err)
}
if err := unix.Setgid(gid); err != nil {
return fmt.Errorf("setgid: %d: %v", gid, err)
}
if err := unix.Setuid(uid); err != nil {
return fmt.Errorf("setuid: %d: %v", uid, err)
}
return nil
}