FileSystem.php
Same filename in this branch
Same filename in other branches
- 8.9.x core/lib/Drupal/Core/File/FileSystem.php
- 8.9.x core/lib/Drupal/Component/FileSystem/FileSystem.php
- 10 core/lib/Drupal/Core/File/FileSystem.php
- 10 core/lib/Drupal/Component/FileSystem/FileSystem.php
- 11.x core/lib/Drupal/Core/File/FileSystem.php
- 11.x core/lib/Drupal/Component/FileSystem/FileSystem.php
Namespace
Drupal\Component\FileSystemFile
-
core/
lib/ Drupal/ Component/ FileSystem/ FileSystem.php
View source
<?php
namespace Drupal\Component\FileSystem;
/**
* Provides file system functions.
*/
class FileSystem {
/**
* Discovers a writable system-appropriate temporary directory.
*
* @return string|false
* A string containing the path to the temporary directory, or FALSE if no
* suitable temporary directory can be found.
*/
public static function getOsTemporaryDirectory() {
$directories = [];
// Has PHP been set with an upload_tmp_dir?
if (ini_get('upload_tmp_dir')) {
$directories[] = ini_get('upload_tmp_dir');
}
// Operating system specific dirs.
if (substr(PHP_OS, 0, 3) == 'WIN') {
$directories[] = 'c:\\windows\\temp';
$directories[] = 'c:\\winnt\\temp';
}
else {
$directories[] = '/tmp';
}
// PHP may be able to find an alternative tmp directory.
$directories[] = sys_get_temp_dir();
foreach ($directories as $directory) {
if (is_dir($directory) && is_writable($directory)) {
// Both sys_get_temp_dir() and ini_get('upload_tmp_dir') can return paths
// with a trailing directory separator.
return rtrim($directory, DIRECTORY_SEPARATOR);
}
}
return FALSE;
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
FileSystem | Provides file system functions. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.