keyctl.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // +build linux
  2. package keys
  3. import (
  4. "fmt"
  5. "strconv"
  6. "strings"
  7. "github.com/pkg/errors"
  8. "golang.org/x/sys/unix"
  9. )
  10. type KeySerial uint32
  11. func JoinSessionKeyring(name string) (KeySerial, error) {
  12. sessKeyId, err := unix.KeyctlJoinSessionKeyring(name)
  13. if err != nil {
  14. return 0, errors.Wrap(err, "create session key")
  15. }
  16. return KeySerial(sessKeyId), nil
  17. }
  18. // ModKeyringPerm modifies permissions on a keyring by reading the current permissions,
  19. // anding the bits with the given mask (clearing permissions) and setting
  20. // additional permission bits
  21. func ModKeyringPerm(ringId KeySerial, mask, setbits uint32) error {
  22. dest, err := unix.KeyctlString(unix.KEYCTL_DESCRIBE, int(ringId))
  23. if err != nil {
  24. return err
  25. }
  26. res := strings.Split(dest, ";")
  27. if len(res) < 5 {
  28. return fmt.Errorf("Destination buffer for key description is too small")
  29. }
  30. // parse permissions
  31. perm64, err := strconv.ParseUint(res[3], 16, 32)
  32. if err != nil {
  33. return err
  34. }
  35. perm := (uint32(perm64) & mask) | setbits
  36. return unix.KeyctlSetperm(int(ringId), perm)
  37. }