xattr_trusted.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #include <linux/reiserfs_fs.h>
  2. #include <linux/errno.h>
  3. #include <linux/fs.h>
  4. #include <linux/pagemap.h>
  5. #include <linux/xattr.h>
  6. #include <linux/reiserfs_xattr.h>
  7. #include <asm/uaccess.h>
  8. #define XATTR_TRUSTED_PREFIX "trusted."
  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
  33. trusted_del (struct inode *inode, const char *name)
  34. {
  35. if (strlen(name) < sizeof(XATTR_TRUSTED_PREFIX))
  36. return -EINVAL;
  37. if (!reiserfs_xattrs (inode->i_sb))
  38. return -EOPNOTSUPP;
  39. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  40. return -EPERM;
  41. return 0;
  42. }
  43. static int
  44. trusted_list (struct inode *inode, const char *name, int namelen, char *out)
  45. {
  46. int len = namelen;
  47. if (!reiserfs_xattrs (inode->i_sb))
  48. return 0;
  49. if (!(capable(CAP_SYS_ADMIN) || is_reiserfs_priv_object(inode)))
  50. return 0;
  51. if (out)
  52. memcpy (out, name, len);
  53. return len;
  54. }
  55. struct reiserfs_xattr_handler trusted_handler = {
  56. .prefix = XATTR_TRUSTED_PREFIX,
  57. .get = trusted_get,
  58. .set = trusted_set,
  59. .del = trusted_del,
  60. .list = trusted_list,
  61. };