TempFileManager.php in Backup and Migrate 5.0.x
Namespace
Drupal\backup_migrate\Core\FileFile
src/Core/File/TempFileManager.phpView source
<?php
namespace Drupal\backup_migrate\Core\File;
/**
*
*
* @package Drupal\backup_migrate\Core\Services
*/
class TempFileManager implements TempFileManagerInterface {
/**
* @var \Drupal\backup_migrate\Core\File\TempFileAdapterInterface
*/
protected $adapter;
/**
* Build the manager with the given adapter.
*
* This manager needs the adapter to create the actual temp files.
*
* @param \Drupal\backup_migrate\Core\File\TempFileAdapterInterface $adapter
*/
public function __construct(TempFileAdapterInterface $adapter) {
$this->adapter = $adapter;
}
/**
* Create a brand new temp file with the given extension (if specified).
*
* The new file should be writable.
*
* @param string $ext
* The file extension for this file (optional)
*
* @return BackupFileWritableInterface
*/
public function create($ext = '') {
$file = new WritableStreamBackupFile($this->adapter
->createTempFile($ext));
$file
->setExtList(explode('.', $ext));
return $file;
}
/**
* Return a new file based on the passed in file with the given file ext.
*
* This should maintain the metadata of the file passed in with the new file
* extension added after the old one.
*
* For example: xxx.mysql would become xxx.mysql.gz.
*
* @param \Drupal\backup_migrate\Core\File\BackupFileInterface $file
* The file to add the extension to.
* @param $ext
* The new file extension.
*
* @return \Drupal\backup_migrate\Core\File\BackupFileWritableInterface
* A new writable backup file with the new extension and all of the metadata
* from the previous file.
*/
public function pushExt(BackupFileInterface $file, $ext) {
// Push the new extension on to the new file.
$parts = $file
->getExtList();
array_push($parts, $ext);
$new_ext = implode('.', $parts);
// Copy the file metadata to a new TempFile.
$out = new WritableStreamBackupFile($this->adapter
->createTempFile($new_ext));
// Copy the file metadata to a new TempFile.
$out
->setMetaMultiple($file
->getMetaAll());
$out
->setName($file
->getName());
$out
->setExtList($parts);
return $out;
}
/**
* Return a new file based on the one passed in.
*
* Has the last part of the file extension removed.
*
* For example: xxx.mysql.gz would become xxx.mysql.
*
* @param \Drupal\backup_migrate\Core\File\BackupFileInterface $file
*
* @return \Drupal\backup_migrate\Core\File\BackupFileWritableInterface
* A new writable backup file with the last extension removed and
* all of the metadata from the previous file.
*/
public function popExt(BackupFileInterface $file) {
// Pop the last extension from the last of the file.
$parts = $file
->getExtList();
array_pop($parts);
$new_ext = implode('.', $parts);
// Create a new temp file with the new extension.
$out = new WritableStreamBackupFile($this->adapter
->createTempFile($new_ext));
// Copy the file metadata to a new TempFile.
$out
->setMetaMultiple($file
->getMetaAll());
$out
->setName($file
->getName());
$out
->setExtList($parts);
return $out;
}
}
Classes
Name | Description |
---|---|
TempFileManager | @package Drupal\backup_migrate\Core\Services |