ISearchQuery.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2017 Robin Appelman <robin@icewind.nl>
  4. *
  5. * @author Robin Appelman <robin@icewind.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\Search;
  24. use OCP\IUser;
  25. /**
  26. * @since 12.0.0
  27. */
  28. interface ISearchQuery {
  29. /**
  30. * @return ISearchOperator
  31. * @since 12.0.0
  32. */
  33. public function getSearchOperation();
  34. /**
  35. * Get the maximum number of results to return
  36. *
  37. * @return integer
  38. * @since 12.0.0
  39. */
  40. public function getLimit();
  41. /**
  42. * Get the offset for returned results
  43. *
  44. * @return integer
  45. * @since 12.0.0
  46. */
  47. public function getOffset();
  48. /**
  49. * The fields and directions to order by
  50. *
  51. * @return ISearchOrder[]
  52. * @since 12.0.0
  53. */
  54. public function getOrder();
  55. /**
  56. * The user that issued the search
  57. *
  58. * @return ?IUser
  59. * @since 12.0.0
  60. */
  61. public function getUser();
  62. /**
  63. * Whether or not the search should be limited to the users home storage
  64. *
  65. * @return bool
  66. * @since 18.0.0
  67. */
  68. public function limitToHome(): bool;
  69. }