xattr_trusted.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #include <linux/reiserfs_fs.h>
  2. #include <linux/capability.h>
  3. #include <linux/errno.h>
  4. #include <linux/fs.h>
  5. #include <linux/pagemap.h>
  6. #include <linux/xattr.h>
  7. #include <linux/reiserfs_xattr.h>
  8. #include <asm/uaccess.h>
  9. static int
  10. trusted_get(struct inode *inode, const char *name, void *buffer, size_t size)
  11. {
  12. if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
  13. return -EINVAL;
  14. if (!reiserfs_xattrs(inode->i_sb))
  15. return -EOPNOTSUPP;
  16. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  17. return -EPERM;
  18. return reiserfs_xattr_get(inode, name, buffer, size);
  19. }
  20. static int
  21. trusted_set(struct inode *inode, const char *name, const void *buffer,
  22. size_t size, int flags)
  23. {
  24. if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
  25. return -EINVAL;
  26. if (!reiserfs_xattrs(inode->i_sb))
  27. return -EOPNOTSUPP;
  28. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  29. return -EPERM;
  30. return reiserfs_xattr_set(inode, name, buffer, size, flags);
  31. }
  32. static int trusted_del(struct inode *inode, const char *name)
  33. {
  34. if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
  35. return -EINVAL;
  36. if (!reiserfs_xattrs(inode->i_sb))
  37. return -EOPNOTSUPP;
  38. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  39. return -EPERM;
  40. return 0;
  41. }
  42. static int
  43. trusted_list(struct inode *inode, const char *name, int namelen, char *out)
  44. {
  45. int len = namelen;
  46. if (!reiserfs_xattrs(inode->i_sb))
  47. return 0;
  48. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  49. return 0;
  50. if (out)
  51. memcpy(out, name, len);
  52. return len;
  53. }
  54. struct reiserfs_xattr_handler trusted_handler = {
  55. .prefix = XATTR_TRUSTED_PREFIX,
  56. .get = trusted_get,
  57. .set = trusted_set,
  58. .del = trusted_del,
  59. .list = trusted_list,
  60. };