elfinder.drupalfs.acl.inc 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. /**
  3. * @file
  4. * elfinder ACL class
  5. */
  6. class elFinderDrupalACL {
  7. public function fsAccessPublic($attr, $path, $data, $volume) {
  8. if (strpos(basename($path), '.') === 0 && $attr == 'hidden') {
  9. return TRUE;
  10. }
  11. /* Hiding thumbnail folder */
  12. if (strstr($path, DIRECTORY_SEPARATOR . variable_get('elfinder_settings_thumbnail_dirname', 'tmb')) && $attr == 'hidden') {
  13. return TRUE;
  14. }
  15. // Hide folders hidden by config settings.
  16. $f = drupal_realpath("public://") . "/";
  17. $folder = str_replace($f, "", $path);
  18. $hidden_folder = preg_split("/[\s,]+/", variable_get('elfinder_settings_misc_hidden_folders', ''));
  19. if (in_array($folder, $hidden_folder) && $attr == 'hidden') {
  20. return TRUE;
  21. }
  22. if (strstr($path, DIRECTORY_SEPARATOR . '.quarantine') && $attr == 'hidden') {
  23. return TRUE;
  24. }
  25. if ($attr == 'read') {
  26. return TRUE;
  27. }
  28. if ($attr == 'write') {
  29. return TRUE;
  30. }
  31. /* if ($attr == 'write' && user_access('write public files')) {
  32. return TRUE;
  33. }
  34. if ($attr == 'locked' && !user_access('write public files')) {
  35. return TRUE;
  36. } */
  37. return FALSE;
  38. }
  39. public function fsAccessPrivate($attr, $path, $data, $volume) {
  40. if (strpos(basename($path), '.') === 0 && $attr == 'hidden') {
  41. return TRUE;
  42. }
  43. /* Hiding thumbnail folder */
  44. if (strstr($path, DIRECTORY_SEPARATOR . variable_get('elfinder_settings_thumbnail_dirname', 'tmb')) && $attr == 'hidden') {
  45. return TRUE;
  46. }
  47. if (strstr($path, DIRECTORY_SEPARATOR . '.quarantine') && $attr == 'hidden') {
  48. return TRUE;
  49. }
  50. if ($attr == 'read') {
  51. return TRUE;
  52. }
  53. if ($attr == 'write') {
  54. return TRUE;
  55. }
  56. /* if ($attr == 'write' && user_access('write public files')) {
  57. return TRUE;
  58. }
  59. if ($attr == 'locked' && !user_access('write public files')) {
  60. return TRUE;
  61. } */
  62. return FALSE;
  63. }
  64. public function fsAccessUnmanaged($attr, $path, $data, $volume) {
  65. if (strpos(basename($path), '.') === 0 && $attr == 'hidden') {
  66. return TRUE;
  67. }
  68. /* Hiding thumbnail folder */
  69. if (strstr($path, DIRECTORY_SEPARATOR . variable_get('elfinder_settings_thumbnail_dirname', 'tmb')) && $attr == 'hidden') {
  70. return TRUE;
  71. }
  72. if (strstr($path, DIRECTORY_SEPARATOR . '.quarantine') && $attr == 'hidden') {
  73. return TRUE;
  74. }
  75. if ($attr == 'read') {
  76. return TRUE;
  77. }
  78. return FALSE;
  79. }
  80. }