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.
This commit is contained in:
state-plumber
2026-05-12 20:39:55 +00:00
committed by GitHub
parent be5daeba7a
commit aaf263957b
4 changed files with 22 additions and 10 deletions

View File

@@ -4,6 +4,6 @@ package main
import "errors" import "errors"
func chuser(user string) error { func chuser(user, adminSockUrl string) error {
return errors.New("setting uid/gid is not supported on this platform") return errors.New("setting uid/gid is not supported on this platform")
} }

View File

@@ -4,6 +4,8 @@ package main
import ( import (
"fmt" "fmt"
"net/url"
"os"
"os/user" "os/user"
"strconv" "strconv"
"strings" "strings"
@@ -11,7 +13,7 @@ import (
"golang.org/x/sys/unix" "golang.org/x/sys/unix"
) )
func chuser(input string) error { func chuser(input, adminSockUrl string) error {
givenUser, givenGroup, _ := strings.Cut(input, ":") givenUser, givenGroup, _ := strings.Cut(input, ":")
if givenUser == "" { if givenUser == "" {
return fmt.Errorf("user is empty") return fmt.Errorf("user is empty")
@@ -48,6 +50,16 @@ func chuser(input string) error {
gid, _ = strconv.Atoi(usr.Gid) 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 { if err := unix.Setgroups([]int{gid}); err != nil {
return fmt.Errorf("setgroups: %d: %v", gid, err) return fmt.Errorf("setgroups: %d: %v", gid, err)
} }

View File

@@ -9,21 +9,21 @@ import (
// Usernames must not contain a number sign. // Usernames must not contain a number sign.
func TestEmptyString(t *testing.T) { func TestEmptyString(t *testing.T) {
if chuser("") == nil { if chuser("", "") == nil {
t.Fatal("the empty string is not a valid user") t.Fatal("the empty string is not a valid user")
} }
} }
// Either omit delimiter and group, or omit both. // Either omit delimiter and group, or omit both.
func TestEmptyGroup(t *testing.T) { func TestEmptyGroup(t *testing.T) {
if chuser("0:") == nil { if chuser("0:", "") == nil {
t.Fatal("the empty group is not allowed") t.Fatal("the empty group is not allowed")
} }
} }
// Either user only or user and group. // Either user only or user and group.
func TestGroupOnly(t *testing.T) { func TestGroupOnly(t *testing.T) {
if chuser(":0") == nil { if chuser(":0", "") == nil {
t.Fatal("group only is not allowed") t.Fatal("group only is not allowed")
} }
} }
@@ -31,14 +31,14 @@ func TestGroupOnly(t *testing.T) {
// Usenames must not contain the number sign. // Usenames must not contain the number sign.
func TestInvalidUsername(t *testing.T) { func TestInvalidUsername(t *testing.T) {
const username = "#user" const username = "#user"
if chuser(username) == nil { if chuser(username, "") == nil {
t.Fatalf("'%s' is not a valid username", username) t.Fatalf("'%s' is not a valid username", username)
} }
} }
// User IDs must be non-negative. // User IDs must be non-negative.
func TestInvalidUserid(t *testing.T) { func TestInvalidUserid(t *testing.T) {
if chuser("-1") == nil { if chuser("-1", "") == nil {
t.Fatal("User ID cannot be negative") t.Fatal("User ID cannot be negative")
} }
} }
@@ -54,7 +54,7 @@ func TestCurrentUserid(t *testing.T) {
t.Skip("setgroups(2): Only the superuser may set new groups.") t.Skip("setgroups(2): Only the superuser may set new groups.")
} }
if err = chuser(usr.Uid); err != nil { if err = chuser(usr.Uid, ""); err != nil {
t.Fatal(err) t.Fatal(err)
} }
} }
@@ -70,7 +70,7 @@ func TestCommonUsername(t *testing.T) {
t.Skip("setgroups(2): Only the superuser may set new groups.") t.Skip("setgroups(2): Only the superuser may set new groups.")
} }
if err := chuser("nobody"); err != nil { if err := chuser("nobody", ""); err != nil {
if _, ok := err.(user.UnknownUserError); ok { if _, ok := err.(user.UnknownUserError); ok {
t.Skip(err) t.Skip(err)
} }

View File

@@ -293,7 +293,7 @@ func main() {
// Change user if requested // Change user if requested
if *chuserto != "" { if *chuserto != "" {
err = chuser(*chuserto) err = chuser(*chuserto, cfg.AdminListen)
if err != nil { if err != nil {
panic(err) panic(err)
} }