ISimpleFolder.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2016 Roeland Jago Douma <roeland@famdouma.nl>
  4. *
  5. * @author Roeland Jago Douma <roeland@famdouma.nl>
  6. *
  7. * @license GNU AGPL version 3 or any later version
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License as
  11. * published by the Free Software Foundation, either version 3 of the
  12. * License, or (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Affero General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. *
  22. */
  23. namespace OCP\Files\SimpleFS;
  24. use OCP\Files\NotFoundException;
  25. use OCP\Files\NotPermittedException;
  26. /**
  27. * Interface ISimpleFolder
  28. *
  29. * @package OCP\Files\SimpleFS
  30. * @since 11.0.0
  31. * @internal This interface is experimental and might change for NC12
  32. */
  33. interface ISimpleFolder {
  34. /**
  35. * Get all the files in a folder
  36. *
  37. * @return ISimpleFile[]
  38. * @since 11.0.0
  39. */
  40. public function getDirectoryListing();
  41. /**
  42. * Check if a file with $name exists
  43. *
  44. * @param string $name
  45. * @return bool
  46. * @since 11.0.0
  47. */
  48. public function fileExists($name);
  49. /**
  50. * Get the file named $name from the folder
  51. *
  52. * @param string $name
  53. * @return ISimpleFile
  54. * @throws NotFoundException
  55. * @since 11.0.0
  56. */
  57. public function getFile($name);
  58. /**
  59. * Creates a new file with $name in the folder
  60. *
  61. * @param string $name
  62. * @return ISimpleFile
  63. * @throws NotPermittedException
  64. * @since 11.0.0
  65. */
  66. public function newFile($name);
  67. /**
  68. * Remove the folder and all the files in it
  69. *
  70. * @throws NotPermittedException
  71. * @since 11.0.0
  72. */
  73. public function delete();
  74. /**
  75. * Get the folder name
  76. *
  77. * @return string
  78. * @since 11.0.0
  79. */
  80. public function getName();
  81. }