2016-12-29 20:59:59 -06:00
|
|
|
<?php
|
2015-07-10 21:59:39 -04:00
|
|
|
|
2015-08-05 10:55:56 -04:00
|
|
|
namespace Amp\File;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
2017-01-11 14:22:06 +01:00
|
|
|
use AsyncInterop\Promise;
|
2016-08-23 23:55:06 -05:00
|
|
|
|
2015-07-30 10:10:53 -04:00
|
|
|
interface Driver {
|
2015-08-12 19:02:41 -04:00
|
|
|
/**
|
|
|
|
* Open a handle for the specified path
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @param string $mode
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<\Amp\File\Handle>
|
2015-08-12 19:02:41 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function open(string $path, string $mode): Promise;
|
2015-08-12 19:02:41 -04:00
|
|
|
|
2015-07-10 21:59:39 -04:00
|
|
|
/**
|
|
|
|
* Execute a file stat operation
|
|
|
|
*
|
|
|
|
* If the requested path does not exist the resulting Promise will resolve to NULL.
|
|
|
|
*
|
|
|
|
* @param string $path The file system path to stat
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<array|null>
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function stat(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
2015-08-08 10:09:07 -04:00
|
|
|
/**
|
|
|
|
* Does the specified path exist?
|
|
|
|
*
|
|
|
|
* This function should never resolve as a failure -- only a successfull bool value
|
|
|
|
* indicating the existence of the specified path.
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<bool>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function exists(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the size in bytes of the file at the specified path.
|
|
|
|
*
|
|
|
|
* If the path does not exist or is not a regular file this
|
|
|
|
* function's returned Promise WILL resolve as a failure.
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<int>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function size(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Does the specified path exist and is it a directory?
|
|
|
|
*
|
|
|
|
* If the path does not exist the returned Promise will resolve
|
|
|
|
* to FALSE and will not reject with an error.
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<bool>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function isdir(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Does the specified path exist and is it a file?
|
|
|
|
*
|
|
|
|
* If the path does not exist the returned Promise will resolve
|
|
|
|
* to FALSE and will not reject with an error.
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<bool>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function isfile(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the path's last modification time as a unix timestamp
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<int>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function mtime(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the path's last access time as a unix timestamp
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<int>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function atime(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the path's creation time as a unix timestamp
|
|
|
|
*
|
|
|
|
* @param string $path An absolute file system path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise<int>
|
2015-08-08 10:09:07 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function ctime(string $path): Promise;
|
2015-08-08 10:09:07 -04:00
|
|
|
|
2015-07-10 21:59:39 -04:00
|
|
|
/**
|
|
|
|
* Same as stat() except if the path is a link then the link's data is returned
|
|
|
|
*
|
|
|
|
* @param string $path The file system path to stat
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise A promise resolving to an associative array upon successful resolution
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function lstat(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a symlink $link pointing to the file/directory located at $target
|
|
|
|
*
|
|
|
|
* @param string $target
|
|
|
|
* @param string $link
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function symlink(string $target, string $link): Promise;
|
2017-01-11 14:22:06 +01:00
|
|
|
|
2016-08-23 23:55:06 -05:00
|
|
|
/**
|
|
|
|
* Create a hard link $link pointing to the file/directory located at $target
|
|
|
|
*
|
|
|
|
* @param string $target
|
|
|
|
* @param string $link
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2016-08-23 23:55:06 -05:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function link(string $target, string $link): Promise;
|
2017-01-11 14:22:06 +01:00
|
|
|
|
2016-08-23 23:55:06 -05:00
|
|
|
/**
|
|
|
|
* Read the symlink at $path.
|
|
|
|
*
|
|
|
|
* @param string $target
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2016-08-23 23:55:06 -05:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function readlink(string $target): Promise;
|
2017-01-11 14:22:06 +01:00
|
|
|
|
2015-07-10 21:59:39 -04:00
|
|
|
/**
|
|
|
|
* Rename a file or directory
|
|
|
|
*
|
|
|
|
* @param string $from
|
|
|
|
* @param string $to
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function rename(string $from, string $to): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a file
|
|
|
|
*
|
|
|
|
* @param string $path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function unlink(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a director
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @param int $mode
|
2016-09-28 13:39:24 +03:00
|
|
|
* @param bool $recursive
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2017-01-11 00:05:18 -06:00
|
|
|
public function mkdir(string $path, int $mode = 0644, bool $recursive = false): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a directory
|
|
|
|
*
|
|
|
|
* @param string $path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function rmdir(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve an array of files and directories inside the specified path
|
|
|
|
*
|
|
|
|
* Dot entries are not included in the resulting array (i.e. "." and "..").
|
|
|
|
*
|
|
|
|
* @param string $path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function scandir(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* chmod a file or directory
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @param int $mode
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function chmod(string $path, int $mode): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* chown a file or directory
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @param int $uid
|
|
|
|
* @param int $gid
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function chown(string $path, int $uid, int $gid): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
2015-07-18 14:53:46 -04:00
|
|
|
/**
|
|
|
|
* Update the access and modification time of the specified path
|
|
|
|
*
|
|
|
|
* If the file does not exist it will be created automatically.
|
|
|
|
*
|
|
|
|
* @param string $path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise
|
2015-07-18 14:53:46 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function touch(string $path): Promise;
|
2015-07-18 14:53:46 -04:00
|
|
|
|
2015-07-10 21:59:39 -04:00
|
|
|
/**
|
|
|
|
* Buffer the specified file's contents
|
|
|
|
*
|
|
|
|
* @param string $path The file path from which to buffer contents
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise A promise resolving to a string upon successful resolution
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function get(string $path): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Write the contents string to the specified path.
|
|
|
|
*
|
|
|
|
* @param string $path The file path to which to $contents should be written
|
|
|
|
* @param string $contents The data to write to the specified $path
|
2017-01-11 14:22:06 +01:00
|
|
|
* @return \AsyncInterop\Promise A promise resolving to the integer length written upon success
|
2015-07-10 21:59:39 -04:00
|
|
|
*/
|
2016-11-14 23:17:19 -06:00
|
|
|
public function put(string $path, string $contents): Promise;
|
2015-07-10 21:59:39 -04:00
|
|
|
}
|