IChunkedFileWrite.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. /*
  3. * @copyright Copyright (c) 2021 Julius Härtl <jus@bitgrid.net>
  4. *
  5. * @author Julius Härtl <jus@bitgrid.net>
  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. declare(strict_types=1);
  24. namespace OCP\Files\Storage;
  25. use OCP\Files\GenericFileException;
  26. /**
  27. * @since 26.0.0
  28. */
  29. interface IChunkedFileWrite extends IStorage {
  30. /**
  31. * @param string $targetPath Relative target path in the storage
  32. * @return string writeToken to be used with the other methods to uniquely identify the file write operation
  33. * @throws GenericFileException
  34. * @since 26.0.0
  35. */
  36. public function startChunkedWrite(string $targetPath): string;
  37. /**
  38. * @param string $targetPath
  39. * @param string $writeToken
  40. * @param string $chunkId
  41. * @param resource $data
  42. * @param int|null $size
  43. * @throws GenericFileException
  44. * @since 26.0.0
  45. */
  46. public function putChunkedWritePart(string $targetPath, string $writeToken, string $chunkId, $data, ?int $size = null): ?array;
  47. /**
  48. * @param string $targetPath
  49. * @param string $writeToken
  50. * @return int
  51. * @throws GenericFileException
  52. * @since 26.0.0
  53. */
  54. public function completeChunkedWrite(string $targetPath, string $writeToken): int;
  55. /**
  56. * @param string $targetPath
  57. * @param string $writeToken
  58. * @throws GenericFileException
  59. * @since 26.0.0
  60. */
  61. public function cancelChunkedWrite(string $targetPath, string $writeToken): void;
  62. }