0
0
Fork 0
mirror of https://github.com/nextcloud/server.git synced 2025-05-20 05:00:15 +00:00
nextcloud_server/lib/public/Files/SimpleFS/ISimpleFile.php
Daniel Kesselberg 866063c198
fix: annotate possible exceptions
File.getContent can throw a GenericFileException since https://github.com/nextcloud/server/pull/37943.

Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
2025-05-13 22:27:19 +02:00

111 lines
2.2 KiB
PHP

<?php
/**
* SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCP\Files\SimpleFS;
use OCP\Files\GenericFileException;
use OCP\Files\NotFoundException;
use OCP\Files\NotPermittedException;
use OCP\Lock\LockedException;
/**
* This interface allows to manage simple files.
*
* This interface must not be implemented in your application but
* instead should be used as a service and injected in your code with
* dependency injection.
*
* @since 11.0.0
*/
interface ISimpleFile {
/**
* Get the name
*
* @since 11.0.0
*/
public function getName(): string;
/**
* Get the size in bytes
*
* @since 11.0.0
*/
public function getSize(): int|float;
/**
* Get the ETag
*
* @since 11.0.0
*/
public function getETag(): string;
/**
* Get the last modification time
*
* @since 11.0.0
*/
public function getMTime(): int;
/**
* Get the content
*
* @throws GenericFileException
* @throws LockedException
* @throws NotFoundException
* @throws NotPermittedException
* @since 11.0.0
*/
public function getContent(): string;
/**
* Overwrite the file
*
* @param string|resource $data
* @throws GenericFileException
* @throws LockedException
* @throws NotFoundException
* @throws NotPermittedException
* @since 11.0.0
*/
public function putContent($data): void;
/**
* Delete the file
*
* @throws NotPermittedException
* @since 11.0.0
*/
public function delete(): void;
/**
* Get the MimeType
*
* @since 11.0.0
*/
public function getMimeType(): string;
/**
* @since 24.0.0
*/
public function getExtension(): string;
/**
* Open the file as stream for reading, resulting resource can be operated as stream like the result from php's own fopen
*
* @return resource|false
* @throws \OCP\Files\NotPermittedException
* @since 14.0.0
*/
public function read();
/**
* Open the file as stream for writing, resulting resource can be operated as stream like the result from php's own fopen
*
* @return resource|bool
* @throws \OCP\Files\NotPermittedException
* @since 14.0.0
*/
public function write();
}