summaryrefslogtreecommitdiffhomepage
path: root/runsc/cmd/boot.go
diff options
context:
space:
mode:
authorLantao Liu <lantaol@google.com>2018-06-26 13:39:07 -0700
committerShentubot <shentubot@google.com>2018-06-26 13:40:04 -0700
commit000fd8d1e4530b4063eead26dda4843ff0d71cbd (patch)
tree1c41986261d239b3cf247cb50fe8c044a1cb5553 /runsc/cmd/boot.go
parentea10949a0036cdef95a1397ccad8fcc138ce3c0d (diff)
runsc: set gofer umask to 0.
PiperOrigin-RevId: 202185642 Change-Id: I2eefcc0b2ffadc6ef21d177a8a4ab0cda91f3399
Diffstat (limited to 'runsc/cmd/boot.go')
-rw-r--r--runsc/cmd/boot.go7
1 files changed, 7 insertions, 0 deletions
diff --git a/runsc/cmd/boot.go b/runsc/cmd/boot.go
index 86f597c09..0d0e6b63f 100644
--- a/runsc/cmd/boot.go
+++ b/runsc/cmd/boot.go
@@ -107,6 +107,13 @@ func (b *Boot) Execute(_ context.Context, f *flag.FlagSet, args ...interface{})
conf := args[0].(*boot.Config)
waitStatus := args[1].(*syscall.WaitStatus)
+ // sentry should run with a umask of 0 when --file-access=direct, because we want
+ // to preserve file modes exactly as set by the sentry, which will have applied
+ // its own umask.
+ if conf.FileAccess == boot.FileAccessDirect {
+ syscall.Umask(0)
+ }
+
if b.applyCaps {
caps := spec.Process.Capabilities
if conf.Platform == boot.PlatformPtrace {