Чтобы управлять файлами и папками в пределах домена, используйте класс pm_FileManager. Этот класс позволяет создавать и удалять файлы и папки, проверять наличие файлов и папок, читать и записывать данные в файлы, а также изменять права файлов и папок (только в Linux).

Примечание: Из соображений безопасности мы настоятельно не рекомендуем вам использовать системные вызовы, такие как fopen или file_get_contents, в коде вашего расширения. Когда вы используете такие вызовы, расширение работает с файлами от имени пользователя psaadm. Если же вы используете класс pm_FileManager, действия выполняются от имени системного пользователя владельца домена.

Описания и примеры использования некоторых методов приведены ниже.

scanDir() – возвращает список файлов и папок внутри папки по указанному пути.

Использование

array scanDir(string $path [, bool $skipDots = false [, bool $showSystemFiles = true ]])

Параметры

  • path (тип: string)

    Папка, которая будет просканирована.

  • skipDots (тип: boolean, значение по умолчанию: false)

    Если для необязательного параметра skipDots задано значение «true», корневые папки «..» и «.» будут исключены из результирующего массива, иначе они будут включены в него.

  • showSystemFiles (тип: boolean, значение по умолчанию: true)

    Если для необязательного параметра showSystemFiles задано значение «true», скрытые файлы (например, системные файлы) будут включены в результирующий массив, иначе они будут отсутствовать в нем.

Возвращаемые значения

Возвращает массив, состоящий из файлов и папок в сканируемой папке.

Примеры

Дерево папок

$ ls -a var
.  ..  config.json  .gitkeep

Пример

$result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir()); // Default use
// analogue:
// $result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir(), false, true);
var_dump($result);

Вывод

array(4) {
  [0]=>
  string(1) "."
  [1]=>
  string(2) ".."
  [2]=>
  string(11) "config.json"
  [3]=>
  string(8) ".gitkeep"
}

Пример

$result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir(), true);
// analogue:
// $result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir(), true, true);
var_dump($result);

Вывод

array(2) {
  [0]=>
  string(11) "config.json"
  [1]=>
  string(8) ".gitkeep"
}

Пример

$result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir(), false, false);
var_dump($result);

Вывод

array(3) {
  [0]=>
  string(1) "."
  [1]=>
  string(2) ".."
  [2]=>
  string(11) "config.json"
}

Пример

$result = (new \pm_FileManager())->scanDir(\pm_Context::getVarDir(), true, false);
var_dump($result);

Вывод

array(1) {
  [0]=>
  string(11) "config.json"
}

joinPath() – возвращает объединенные части пути.

Использование

string joinPath(string ...$pathParts)

Параметры

  • pathParts (тип: string, можно указать одно или больше значений)

Возвращаемые значения

Строка, содержащая строковое представление всех указанных частей пути, расположенных в том же порядке и разделенных с помощью DIRECTORY_SEPARATOR.

Пример

$result = (new \pm_FileManager())->joinPath('var', 'config', 'config.json');
var_dump($result);

Вывод

string(22) "var/config/config.json"

isSubpath() – проверяет, является ли папка по указанному пути подпапкой корневой папки веб-пространства.

Использование

bool isSubpath(string $path)

Параметры

  • path (тип: string)

Возвращаемые значения

«True» – если папка находится внутри основной папки, иначе – «false».

Примеры

Пример

$result = (new \pm_FileManager())->isSubpath('/var/www/vhosts/a.a/httpdocs/qwe/qwe/ddd/wqecfds');
var_dump($result);

Вывод

bool(true)

Пример

// assuming that the webspace document root is '/var/www/vhosts/a.a/'
$result1 = (new \pm_FileManager(1))->isSubpath('/var/www/vhosts/a.a/httpdocs/qwe/qwe/ddd/wqecfds');
$result2 = (new \pm_FileManager(1))->isSubpath('/var/www/vhosts/b.b/httpdocs/qwe/qwe/ddd/wqecfds');
var_dump($result1);
var_dump($result2);

Вывод

bool(true)
bool(false)

getRelativeFilePath() – возвращает путь относительно корневой папки веб-пространства для указанного абсолютного пути.

Использование

string getRelativeFilePath(string $path)

Параметры

  • path (тип: string, абсолютный путь)

Возвращаемые значения

Относительный путь в корневой папке.

Примеры

Пример

$result = (new \pm_FileManager())->getRelativeFilePath('/var/www/vhosts/a.a/httpdocs/qwe/qwe/ddd/wqecfds');
var_dump($result);

Вывод

string(47) "var/www/vhosts/a.a/httpdocs/qwe/qwe/ddd/wqecfds"

Пример

// assuming that webspace document root is '/var/www/vhosts/a.a/'
$result1 = (new \pm_FileManager(1))->getRelativeFilePath('/var/www/vhosts/a.a/httpdocs/qwe/qwe/ddd/wqecfds');
$result2 = (new \pm_FileManager(1))->getRelativeFilePath('/var/www/vhosts/b.b/httpdocs/qwe/qwe/ddd/wqecfds');
var_dump($result1);
var_dump($result2);

Вывод

string(28) "httpdocs/qwe/qwe/ddd/wqecfds"
string(35) "../b.b/httpdocs/qwe/qwe/ddd/wqecfds"

copyFile() – копирует объекты файловой системы (файлы и папки) из исходной папки в целевую. Папки копируются рекурсивно.

Использование

copyFile(string $source, string $destination)

Параметры

  • source (тип: string, полный путь к исходной папке)
  • destination (тип: string, полный путь к целевой папке)

Пример

(new \pm_FileManager())->copyFile('/tmp/source', '/tmp/destination');

Ниже приводится пример работы с файлами домена. В этом примере выполняются некоторые действия с содержимым файла. Используются следующие методы:

Используйте следующий код:

$fileManager = new pm_FileManager($domainId);
$filePath = $fileManager->getFilePath("$currentDir/$file");
if ($fileManager->fileExists($filePath)) {
    $fileData = $fileManager->fileGetContents($filePath);
    // Some manipulation with file data...
    $fileData = str_replace('foo', 'bar', $fileData);

    $fileManager->filePutContents($filePath, $fileData);
}

Здесь $filePath – абсолютный путь. Он получен из относительного пути в папке домена $currentDir с помощью вызова метода getFilePath().