summaryrefslogtreecommitdiff
path: root/utils/isolate.go
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-12-26 01:02:46 +0300
committerGitHub <[email protected]>2021-12-26 01:02:46 +0300
commit7b5d220f0f1be155d83d887cd4996bdf4394c570 (patch)
tree129d9d1fd1d2803712fa4b0f05d5cfbf466d10e3 /utils/isolate.go
parent9cbb6be27ca0bd56eaa6db9a875830a8ce6110e8 (diff)
parentb27b2a1c9030f38e729e6e2d411379047c28402e (diff)
[#881]: feat(logger): implement common loggerv2.7.0-beta.1
Diffstat (limited to 'utils/isolate.go')
-rwxr-xr-xutils/isolate.go60
1 files changed, 60 insertions, 0 deletions
diff --git a/utils/isolate.go b/utils/isolate.go
new file mode 100755
index 00000000..202f538c
--- /dev/null
+++ b/utils/isolate.go
@@ -0,0 +1,60 @@
+//go:build !windows
+// +build !windows
+
+package utils
+
+import (
+ "fmt"
+ "os"
+ "os/exec"
+ "os/user"
+ "strconv"
+ "syscall"
+
+ "github.com/spiral/errors"
+)
+
+// IsolateProcess change gpid for the process to avoid bypassing signals to php processes.
+func IsolateProcess(cmd *exec.Cmd) {
+ cmd.SysProcAttr = &syscall.SysProcAttr{Setpgid: true, Pgid: 0}
+}
+
+// ExecuteFromUser may work only if run RR under root user
+func ExecuteFromUser(cmd *exec.Cmd, u string) error {
+ const op = errors.Op("execute_from_user")
+ usr, err := user.Lookup(u)
+ if err != nil {
+ return errors.E(op, err)
+ }
+
+ usrI32, err := strconv.ParseInt(usr.Uid, 10, 32)
+ if err != nil {
+ return errors.E(op, err)
+ }
+
+ grI32, err := strconv.ParseInt(usr.Gid, 10, 32)
+ if err != nil {
+ return errors.E(op, err)
+ }
+
+ // For more information:
+ // https://www.man7.org/linux/man-pages/man7/user_namespaces.7.html
+ // https://www.man7.org/linux/man-pages/man7/namespaces.7.html
+ if _, err := os.Stat("/proc/self/ns/user"); err != nil {
+ if os.IsNotExist(err) {
+ return fmt.Errorf("kernel doesn't support user namespaces")
+ }
+ if os.IsPermission(err) {
+ return fmt.Errorf("unable to test user namespaces due to permissions")
+ }
+
+ return errors.E(op, errors.Errorf("failed to stat /proc/self/ns/user: %v", err))
+ }
+
+ cmd.SysProcAttr.Credential = &syscall.Credential{
+ Uid: uint32(usrI32),
+ Gid: uint32(grI32),
+ }
+
+ return nil
+}