mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 02:04:43 +08:00 
			
		
		
		
	 f711f5a68d
			
		
	
	f711f5a68d
	
	
	
		
			
			do not check whether the specified ID is valid in the user namespace.
crun handles this case[1], so the check in Podman prevents to get to
the OCI runtime at all.
$ podman run --user 10:0 --uidmap 0:0:1 --rm -ti fedora:33 sh -c 'id; cat /proc/self/uid_map'
uid=10(10) gid=0(root) groups=0(root),65534(nobody)
        10          0          1
[1] https://github.com/containers/crun/pull/556
Signed-off-by: Giuseppe Scrivano <gscrivan@redhat.com>
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package util
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"path/filepath"
 | |
| 	"syscall"
 | |
| 
 | |
| 	"github.com/containers/psgo"
 | |
| 	"github.com/pkg/errors"
 | |
| 	"github.com/sirupsen/logrus"
 | |
| )
 | |
| 
 | |
| // GetContainerPidInformationDescriptors returns a string slice of all supported
 | |
| // format descriptors of GetContainerPidInformation.
 | |
| func GetContainerPidInformationDescriptors() ([]string, error) {
 | |
| 	return psgo.ListDescriptors(), nil
 | |
| }
 | |
| 
 | |
| // FindDeviceNodes parses /dev/ into a set of major:minor -> path, where
 | |
| // [major:minor] is the device's major and minor numbers formatted as, for
 | |
| // example, 2:0 and path is the path to the device node.
 | |
| // Symlinks to nodes are ignored.
 | |
| func FindDeviceNodes() (map[string]string, error) {
 | |
| 	nodes := make(map[string]string)
 | |
| 	err := filepath.Walk("/dev", func(path string, info os.FileInfo, err error) error {
 | |
| 		if err != nil {
 | |
| 			logrus.Warnf("Error descending into path %s: %v", path, err)
 | |
| 			return filepath.SkipDir
 | |
| 		}
 | |
| 
 | |
| 		// If we aren't a device node, do nothing.
 | |
| 		if info.Mode()&(os.ModeDevice|os.ModeCharDevice) == 0 {
 | |
| 			return nil
 | |
| 		}
 | |
| 
 | |
| 		// We are a device node. Get major/minor.
 | |
| 		sysstat, ok := info.Sys().(*syscall.Stat_t)
 | |
| 		if !ok {
 | |
| 			return errors.Errorf("Could not convert stat output for use")
 | |
| 		}
 | |
| 		major := sysstat.Rdev / 256
 | |
| 		minor := sysstat.Rdev % 256
 | |
| 
 | |
| 		nodes[fmt.Sprintf("%d:%d", major, minor)] = path
 | |
| 
 | |
| 		return nil
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return nodes, nil
 | |
| }
 |