Ver Fonte

Merge pull request #36756 from redbaron/userns-copy-fifo-fix

Fix FIFO, sockets and device files when run in user NS
Tõnis Tiigi há 7 anos atrás
pai
commit
7410b04649
1 ficheiros alterados com 4 adições e 4 exclusões
  1. 4 4
      daemon/graphdriver/copy/copy.go

+ 4 - 4
daemon/graphdriver/copy/copy.go

@@ -189,15 +189,15 @@ func DirCopy(srcDir, dstDir string, copyMode Mode, copyXattrs bool) error {
 		case os.ModeNamedPipe:
 		case os.ModeNamedPipe:
 			fallthrough
 			fallthrough
 		case os.ModeSocket:
 		case os.ModeSocket:
-			if rsystem.RunningInUserNS() {
-				// cannot create a device if running in user namespace
-				return nil
-			}
 			if err := unix.Mkfifo(dstPath, stat.Mode); err != nil {
 			if err := unix.Mkfifo(dstPath, stat.Mode); err != nil {
 				return err
 				return err
 			}
 			}
 
 
 		case os.ModeDevice:
 		case os.ModeDevice:
+			if rsystem.RunningInUserNS() {
+				// cannot create a device if running in user namespace
+				return nil
+			}
 			if err := unix.Mknod(dstPath, stat.Mode, int(stat.Rdev)); err != nil {
 			if err := unix.Mknod(dstPath, stat.Mode, int(stat.Rdev)); err != nil {
 				return err
 				return err
 			}
 			}