FilePermissionsMask.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * Copyright (c) 2021, Xavier Defrang <xavier.defrang@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Error.h>
  8. #include <AK/OwnPtr.h>
  9. #include <sys/stat.h>
  10. namespace Core {
  11. class FilePermissionsMask {
  12. public:
  13. static ErrorOr<FilePermissionsMask> parse(StringView string);
  14. static ErrorOr<FilePermissionsMask> from_numeric_notation(StringView string);
  15. static ErrorOr<FilePermissionsMask> from_symbolic_notation(StringView string);
  16. FilePermissionsMask()
  17. : m_clear_mask(0)
  18. , m_write_mask(0)
  19. {
  20. }
  21. FilePermissionsMask& assign_permissions(mode_t mode);
  22. FilePermissionsMask& add_permissions(mode_t mode);
  23. FilePermissionsMask& remove_permissions(mode_t mode);
  24. mode_t apply(mode_t mode) const
  25. {
  26. if (m_directory_or_executable_mask && (S_ISDIR(mode) || (mode & 0111) != 0))
  27. mode = m_directory_or_executable_mask->apply(mode);
  28. return m_write_mask | (mode & ~m_clear_mask);
  29. }
  30. mode_t clear_mask() const { return m_clear_mask; }
  31. mode_t write_mask() const { return m_write_mask; }
  32. FilePermissionsMask& directory_or_executable_mask()
  33. {
  34. if (!m_directory_or_executable_mask)
  35. m_directory_or_executable_mask = make<FilePermissionsMask>();
  36. return *m_directory_or_executable_mask;
  37. }
  38. private:
  39. mode_t m_clear_mask; // the bits that will be cleared
  40. mode_t m_write_mask; // the bits that will be set
  41. // A separate mask, only for files that already have some executable bit set or directories.
  42. OwnPtr<FilePermissionsMask> m_directory_or_executable_mask;
  43. };
  44. }