123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?php namespace Laravel;
- class File {
- /**
- * Determine if a file exists.
- *
- * @param string $path
- * @return bool
- */
- public static function exists($path)
- {
- return file_exists($path);
- }
- /**
- * Get the contents of a file.
- *
- * @param string $path
- * @return string
- */
- public static function get($path)
- {
- return file_get_contents($path);
- }
- /**
- * Write to a file.
- *
- * @param string $path
- * @param string $data
- * @return int
- */
- public static function put($path, $data)
- {
- return file_put_contents($path, $data, LOCK_EX);
- }
- /**
- * Append to a file.
- *
- * @param string $path
- * @param string $data
- * @return int
- */
- public static function append($path, $data)
- {
- return file_put_contents($path, $data, LOCK_EX | FILE_APPEND);
- }
- /**
- * Delete a file.
- *
- * @param string $path
- * @return void
- */
- public static function delete($path)
- {
- if (static::exists($path)) @unlink($path);
- }
- /**
- * Extract the file extension from a file path.
- *
- * @param string $path
- * @return string
- */
- public static function extension($path)
- {
- return pathinfo($path, PATHINFO_EXTENSION);
- }
- /**
- * Get the file type of a given file.
- *
- * @param string $path
- * @return string
- */
- public static function type($path)
- {
- return filetype($path);
- }
- /**
- * Get the file size of a given file.
- *
- * @param string $file
- * @return int
- */
- public static function size($path)
- {
- return filesize($path);
- }
- /**
- * Get the file's last modification time.
- *
- * @param string $path
- * @return int
- */
- public static function modified($path)
- {
- return filemtime($path);
- }
- /**
- * Move an uploaded file to permanenet storage.
- *
- * @param string $key
- * @param string $path
- * @param array $files
- * @return bool
- */
- public static function upload($key, $path, $files)
- {
- return move_uploaded_file($files[$key]['tmp_name'], $path);
- }
- /**
- * Get a file MIME type by extension.
- *
- * If the MIME type can't be determined, "application/octet-stream" will be returned.
- *
- * <code>
- * // Returns 'application/x-tar'
- * $mime = File::mime('path/to/file.tar');
- * </code>
- *
- * @param string $extension
- * @param string $default
- * @return string
- */
- public static function mime($extension, $default = 'application/octet-stream')
- {
- $mimes = Config::get('mimes');
- if ( ! array_key_exists($extension, $mimes)) return $default;
- return (is_array($mimes[$extension])) ? $mimes[$extension][0] : $mimes[$extension];
- }
- /**
- * Determine if a file is a given type.
- *
- * The Fileinfo PHP extension will be used to determine the MIME type of the file.
- *
- * <code>
- * // Determine if a file is a JPG image
- * $image = File::is('jpg', 'path/to/image.jpg');
- *
- * // Determine if a file is any one of an array of types
- * $image = File::is(array('jpg', 'png', 'gif'), 'path/to/image.jpg');
- * </code>
- *
- * @param array|string $extension
- * @param string $path
- * @return bool
- */
- public static function is($extensions, $path)
- {
- $mimes = Config::get('mimes');
- foreach ((array) $extensions as $extension)
- {
- $mime = finfo_file(finfo_open(FILEINFO_MIME_TYPE), $path);
- if (isset($mimes[$extension]) and in_array((array) $mimes[$extension])) return true;
- }
- return false;
- }
- }
|