123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OCP\Files;
- use OCP\Files\Storage\IStorage;
- /**
- * Interface FileInfo
- *
- * @since 7.0.0
- */
- interface FileInfo {
- /**
- * @since 7.0.0
- */
- public const TYPE_FILE = 'file';
- /**
- * @since 7.0.0
- */
- public const TYPE_FOLDER = 'dir';
- /**
- * @const \OCP\Files\FileInfo::SPACE_NOT_COMPUTED Return value for a not computed space value
- * @since 8.0.0
- */
- public const SPACE_NOT_COMPUTED = -1;
- /**
- * @const \OCP\Files\FileInfo::SPACE_UNKNOWN Return value for unknown space value
- * @since 8.0.0
- */
- public const SPACE_UNKNOWN = -2;
- /**
- * @const \OCP\Files\FileInfo::SPACE_UNLIMITED Return value for unlimited space
- * @since 8.0.0
- */
- public const SPACE_UNLIMITED = -3;
- /**
- * @since 9.1.0
- */
- public const MIMETYPE_FOLDER = 'httpd/unix-directory';
- /**
- * @const \OCP\Files\FileInfo::BLACKLIST_FILES_REGEX Return regular expression to test filenames against (blacklisting)
- * @since 12.0.0
- */
- public const BLACKLIST_FILES_REGEX = '\.(part|filepart)$';
- /**
- * Get the Etag of the file or folder
- *
- * @return string
- * @since 7.0.0
- */
- public function getEtag();
- /**
- * Get the size in bytes for the file or folder
- *
- * @param bool $includeMounts whether or not to include the size of any sub mounts, since 16.0.0
- * @return int|float
- * @since 7.0.0
- */
- public function getSize($includeMounts = true);
- /**
- * Get the last modified date as timestamp for the file or folder
- *
- * @return int
- * @since 7.0.0
- */
- public function getMtime();
- /**
- * Get the name of the file or folder
- *
- * @return string
- * @since 7.0.0
- */
- public function getName();
- /**
- * Get the path relative to the storage
- *
- * @return string
- * @since 7.0.0
- */
- public function getInternalPath();
- /**
- * Get the absolute path
- *
- * @return string
- * @since 7.0.0
- */
- public function getPath();
- /**
- * Get the full mimetype of the file or folder i.e. 'image/png'
- *
- * @return string
- * @since 7.0.0
- */
- public function getMimetype();
- /**
- * Get the first part of the mimetype of the file or folder i.e. 'image'
- *
- * @return string
- * @since 7.0.0
- */
- public function getMimePart();
- /**
- * Get the storage the file or folder is storage on
- *
- * @return IStorage
- * @since 7.0.0
- */
- public function getStorage();
- /**
- * Get the file id of the file or folder
- *
- * @return int|null
- * @since 7.0.0
- */
- public function getId();
- /**
- * Check whether the file is encrypted
- *
- * @return bool
- * @since 7.0.0
- */
- public function isEncrypted();
- /**
- * Get the permissions of the file or folder as bitmasked combination of the following constants
- * \OCP\Constants::PERMISSION_CREATE
- * \OCP\Constants::PERMISSION_READ
- * \OCP\Constants::PERMISSION_UPDATE
- * \OCP\Constants::PERMISSION_DELETE
- * \OCP\Constants::PERMISSION_SHARE
- * \OCP\Constants::PERMISSION_ALL
- *
- * @return int
- * @since 7.0.0 - namespace of constants has changed in 8.0.0
- */
- public function getPermissions();
- /**
- * Check whether this is a file or a folder
- *
- * @return string \OCP\Files\FileInfo::TYPE_FILE|\OCP\Files\FileInfo::TYPE_FOLDER
- * @since 7.0.0
- */
- public function getType();
- /**
- * Check if the file or folder is readable
- *
- * @return bool
- * @since 7.0.0
- */
- public function isReadable();
- /**
- * Check if a file is writable
- *
- * @return bool
- * @since 7.0.0
- */
- public function isUpdateable();
- /**
- * Check whether new files or folders can be created inside this folder
- *
- * @return bool
- * @since 8.0.0
- */
- public function isCreatable();
- /**
- * Check if a file or folder can be deleted
- *
- * @return bool
- * @since 7.0.0
- */
- public function isDeletable();
- /**
- * Check if a file or folder can be shared
- *
- * @return bool
- * @since 7.0.0
- */
- public function isShareable();
- /**
- * Check if a file or folder is shared
- *
- * @return bool
- * @since 7.0.0
- */
- public function isShared();
- /**
- * Check if a file or folder is mounted
- *
- * @return bool
- * @since 7.0.0
- */
- public function isMounted();
- /**
- * Get the mountpoint the file belongs to
- *
- * @return \OCP\Files\Mount\IMountPoint
- * @since 8.0.0
- */
- public function getMountPoint();
- /**
- * Get the owner of the file
- *
- * @return ?\OCP\IUser
- * @since 9.0.0
- */
- public function getOwner();
- /**
- * Get the stored checksum(s) for this file
- *
- * Checksums are stored in the format TYPE:CHECKSUM, here may be multiple checksums separated by a single space
- * e.g. MD5:d3b07384d113edec49eaa6238ad5ff00 SHA1:f1d2d2f924e986ac86fdf7b36c94bcdf32beec15
- *
- * @return string
- * @since 9.0.0
- */
- public function getChecksum();
- /**
- * Get the extension of the file
- *
- * @return string
- * @since 15.0.0
- */
- public function getExtension(): string;
- /**
- * Get the creation date as unix timestamp
- *
- * If the creation time is not known, 0 will be returned
- *
- * creation time is not set automatically by the server and is generally only available
- * for files uploaded by the sync clients
- *
- * @return int
- * @since 18.0.0
- */
- public function getCreationTime(): int;
- /**
- * Get the upload date as unix timestamp
- *
- * If the upload time is not known, 0 will be returned
- *
- * Upload time will be set automatically by the server for files uploaded over DAV
- * files created by Nextcloud apps generally do not have an the upload time set
- *
- * @return int
- * @since 18.0.0
- */
- public function getUploadTime(): int;
- /**
- * Get the fileid or the parent folder
- * or -1 if this item has no parent folder (because it is the root)
- *
- * @return int
- * @since 28.0.0
- */
- public function getParentId(): int;
- /**
- * Get the metadata, if available
- *
- * @return array<string, int|string|bool|float|string[]|int[]>
- * @since 28.0.0
- */
- public function getMetadata(): array;
- }
|