file.php 7.57 KB
Newer Older
1
<?php namespace Laravel; use Closure, FilesystemIterator as fIterator;
2 3

class File {
Taylor Otwell committed
4

5
	/**
6 7 8 9 10
	 * Determine if a file exists.
	 *
	 * @param  string  $path
	 * @return bool
	 */
11
	public static function exists($path)
12 13 14 15 16
	{
		return file_exists($path);
	}

	/**
17
	 * Get the contents of a file.
18
	 *
19 20
	 * <code>
	 *		// Get the contents of a file
Taylor Otwell committed
21
	 *		$contents = File::get(path('app').'routes'.EXT);
22 23
	 *
	 *		// Get the contents of a file or return a default value if it doesn't exist
Taylor Otwell committed
24
	 *		$contents = File::get(path('app').'routes'.EXT, 'Default Value');
25 26
	 * </code>
	 *
27
	 * @param  string  $path
28
	 * @param  mixed   $default
29
	 * @return string
30
	 */
31
	public static function get($path, $default = null)
32
	{
33
		return (file_exists($path)) ? file_get_contents($path) : value($default);
34
	}
35

36 37 38 39 40 41 42
	/**
	 * Write to a file.
	 *
	 * @param  string  $path
	 * @param  string  $data
	 * @return int
	 */
43
	public static function put($path, $data)
44 45 46
	{
		return file_put_contents($path, $data, LOCK_EX);
	}
47

48 49 50 51 52 53 54
	/**
	 * Append to a file.
	 *
	 * @param  string  $path
	 * @param  string  $data
	 * @return int
	 */
55
	public static function append($path, $data)
56 57
	{
		return file_put_contents($path, $data, LOCK_EX | FILE_APPEND);
58 59 60
	}

	/**
61 62 63 64 65
	 * Delete a file.
	 *
	 * @param  string  $path
	 * @return void
	 */
66
	public static function delete($path)
67
	{
68
		if (static::exists($path)) @unlink($path);
69 70 71
	}

	/**
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
	 * Move a file to a new location.
	 *
	 * @param  string  $path
	 * @param  string  $target
	 * @return void
	 */
	public static function move($path, $target)
	{
		return rename($path, $target);
	}

	/**
	 * Copy a file to a new location.
	 *
	 * @param  string  $path
	 * @param  string  $target
	 * @return void
	 */
	public static function copy($path, $target)
	{
		return copy($path, $target);
	}

	/**
Taylor Otwell committed
96
	 * Extract the file extension from a file path.
97
	 * 
Taylor Otwell committed
98
	 * @param  string  $path
99 100
	 * @return string
	 */
101
	public static function extension($path)
102 103 104 105
	{
		return pathinfo($path, PATHINFO_EXTENSION);
	}

106
	/**
107 108 109 110 111
	 * Get the file type of a given file.
	 *
	 * @param  string  $path
	 * @return string
	 */
112
	public static function type($path)
113 114 115 116 117 118 119
	{
		return filetype($path);
	}

	/**
	 * Get the file size of a given file.
	 *
Phill Sparks committed
120
	 * @param  string  $path
121 122
	 * @return int
	 */
123
	public static function size($path)
124 125 126 127 128 129 130 131 132 133
	{
		return filesize($path);
	}

	/**
	 * Get the file's last modification time.
	 *
	 * @param  string  $path
	 * @return int
	 */
134
	public static function modified($path)
135 136 137 138 139
	{
		return filemtime($path);
	}

	/**
140
	 * Get a file MIME type by extension.
141
	 *
142 143 144 145 146 147 148 149
	 * <code>
	 *		// Determine the MIME type for the .tar extension
	 *		$mime = File::mime('tar');
	 *
	 *		// Return a default value if the MIME can't be determined
	 *		$mime = File::mime('ext', 'application/octet-stream');
	 * </code>
	 *
150 151 152 153
	 * @param  string  $extension
	 * @param  string  $default
	 * @return string
	 */
154
	public static function mime($extension, $default = 'application/octet-stream')
155
	{
156 157 158
		$mimes = Config::get('mimes');

		if ( ! array_key_exists($extension, $mimes)) return $default;
159

160
		return (is_array($mimes[$extension])) ? $mimes[$extension][0] : $mimes[$extension];
161 162
	}

163
	/**
Taylor Otwell committed
164 165
	 * Determine if a file is a given type.
	 *
166
	 * The Fileinfo PHP extension is used to determine the file's MIME type.
Taylor Otwell committed
167
	 *
168 169 170 171 172 173 174 175
	 * <code>
	 *		// Determine if a file is a JPG image
	 *		$jpg = File::is('jpg', 'path/to/file.jpg');
	 *
	 *		// Determine if a file is one of a given list of types
	 *		$image = File::is(array('jpg', 'png', 'gif'), 'path/to/file');
	 * </code>
	 *
Phill Sparks committed
176
	 * @param  array|string  $extensions
177
	 * @param  string        $path
Taylor Otwell committed
178
	 * @return bool
Taylor Otwell committed
179
	 */
180
	public static function is($extensions, $path)
Taylor Otwell committed
181
	{
182 183
		$mimes = Config::get('mimes');

184 185 186 187
		$mime = finfo_file(finfo_open(FILEINFO_MIME_TYPE), $path);

		// The MIME configuration file contains an array of file extensions and
		// their associated MIME types. We will spin through each extension the
Taylor Otwell committed
188
		// developer wants to check and look for the MIME type.
189
		foreach ((array) $extensions as $extension)
Taylor Otwell committed
190
		{
191 192 193 194
			if (isset($mimes[$extension]) and in_array($mime, (array) $mimes[$extension]))
			{
				return true;
			}
195
		}
Taylor Otwell committed
196

197
		return false;
Taylor Otwell committed
198 199
	}

200
	/**
Taylor Otwell committed
201 202 203 204 205 206 207 208 209 210 211 212
	 * Create a new directory.
	 *
	 * @param  string  $path
	 * @param  int     $chmod
	 * @return void
	 */
	public static function mkdir($path, $chmod = 0777)
	{
		return ( ! is_dir($path)) ? mkdir($path, $chmod, true) : true;
	}

	/**
213 214 215 216 217 218 219 220 221
	 * Move a directory from one location to another.
	 *
	 * @param  string  $source
	 * @param  string  $destination
	 * @param  int     $options
	 * @return void
	 */
	public static function mvdir($source, $destination, $options = fIterator::SKIP_DOTS)
	{
222
		return static::cpdir($source, $destination, true, $options);
223 224 225
	}

	/**
226 227 228 229
	 * Recursively copy directory contents to another directory.
	 *
	 * @param  string  $source
	 * @param  string  $destination
230
	 * @param  bool    $delete
231
	 * @param  int     $options
232 233
	 * @return void
	 */
234
	public static function cpdir($source, $destination, $delete = false, $options = fIterator::SKIP_DOTS)
235
	{
236
		if ( ! is_dir($source)) return false;
237 238 239 240 241 242

		// First we need to create the destination directory if it doesn't
		// already exists. This directory hosts all of the assets we copy
		// from the installed bundle's source directory.
		if ( ! is_dir($destination))
		{
243
			mkdir($destination, 0777, true);
244 245
		}

246
		$items = new fIterator($source, $options);
247 248 249 250 251 252 253 254 255 256 257 258 259

		foreach ($items as $item)
		{
			$location = $destination.DS.$item->getBasename();

			// If the file system item is a directory, we will recurse the
			// function, passing in the item directory. To get the proper
			// destination path, we'll add the basename of the source to
			// to the destination directory.
			if ($item->isDir())
			{
				$path = $item->getRealPath();

260
				if (! static::cpdir($path, $location, $delete, $options)) return false;
261

262
				if ($delete) @rmdir($item->getRealPath());
263 264 265 266 267 268 269
			}
			// If the file system item is an actual file, we can copy the
			// file from the bundle asset directory to the public asset
			// directory. The "copy" method will overwrite any existing
			// files with the same name.
			else
			{
270
				if(! copy($item->getRealPath(), $location)) return false;
271

272
				if ($delete) @unlink($item->getRealPath());
273 274
			}
		}
275 276

		if ($delete) rmdir($source);
277 278
		
		return true;
279 280
	}

281
	/**
282
	 * Recursively delete a directory.
283
	 *
284
	 * @param  string  $directory
285
	 * @param  bool    $preserve
286 287
	 * @return void
	 */
288
	public static function rmdir($directory, $preserve = false)
289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308
	{
		if ( ! is_dir($directory)) return;

		$items = new fIterator($directory);

		foreach ($items as $item)
		{
			// If the item is a directory, we can just recurse into the
			// function and delete that sub-directory, otherwise we'll
			// just deleete the file and keep going!
			if ($item->isDir())
			{
				static::rmdir($item->getRealPath());
			}
			else
			{
				@unlink($item->getRealPath());
			}
		}

309
		if ( ! $preserve) @rmdir($directory);
310 311 312
	}

	/**
Taylor Otwell committed
313 314 315 316 317 318 319 320 321 322 323
	 * Empty the specified directory of all files and folders.
	 *
	 * @param  string  $directory
	 * @return void
	 */
	public static function cleandir($directory)
	{
		return static::rmdir($directory, true);
	}

	/**
324 325 326
	 * Get the most recently modified file in a directory.
	 *
	 * @param  string       $directory
327
	 * @param  int          $options
328 329
	 * @return SplFileInfo
	 */
330
	public static function latest($directory, $options = fIterator::SKIP_DOTS)
331 332 333
	{
		$time = 0;

334
		$items = new fIterator($directory, $options);
335 336 337

		// To get the latest created file, we'll simply spin through the
		// directory, setting the latest file if we encounter a file
Taylor Otwell committed
338
		// with a UNIX timestamp greater than the latest one.
339 340 341 342 343 344 345 346
		foreach ($items as $item)
		{
			if ($item->getMTime() > $time) $latest = $item;
		}

		return $latest;
	}

347
}