Create temporary files and directories in PHP, safely.
Sadly PHP is deficient when it comes to creating temporary files and directories in a safe and secure manner. This library aims to address these short-comings.
-
Cs278\Mktemp\temporaryFile(string|null $template, string|null $dir)
Create a temporary file with a supplied template for the name.
The template should be a string containing a sequence of at least 3 consecutive
X
characters, these characters will be replaced with a random component. The last valid sequence in the string will be used. If this argument isnull
a defaulttmp.XXXXXX
template will be used.The directory should be a path that exists and the user can write to, if this argument is not supplied the default temporary directory will be used.
A
Cs278\Mktemp\Exception\CreateFailedException
will be thrown if a file cannot be created.use function Cs278\Mktemp\temporaryFile; var_dump(temporaryFile()); // /tmp/tmp.P9aLnd var_dump(temporaryFile('output.XXXX.pdf')); // /tmp/output.oI7b.pdf var_dump(temporaryFile(null, '/var/tmp')); // /var/tmp/tmp.8uJx var_dump(temporaryFile('test.XXX.html', '/var/tmp')); // /var/tmp/test.9h2.html
-
Cs278\Mktemp\temporaryDir(string|null $template, string|null $dir)
Create a temporary directory with a supplied template for the name.
The template should be a string containing a sequence of at least 3 consecutive
X
characters, these characters will be replaced with a random component. The last valid sequence in the string will be used. If this argument isnull
a defaulttmp.XXXXXX
template will be used.The directory should be a path that exists and the user can write to, if this argument is not supplied the default temporary directory will be used.
A
Cs278\Mktemp\Exception\CreateFailedException
will be thrown if a directory cannot be created.use function Cs278\Mktemp\temporaryDir; var_dump(temporaryDir()); // /tmp/tmp.P9aLnd var_dump(temporaryDir('output.XXXX.pdf')); // /tmp/output.oI7b.pdf var_dump(temporaryDir(null, '/var/tmp')); // /var/tmp/tmp.8uJx var_dump(temporaryDir('test.XXX.html', '/var/tmp')); // /var/tmp/test.9h2.html
-
TempFile::__construct(string|null $template, string|null $dir)
Create a temporary file object that manages the life cycle of the file system entity.
Arguments are the same as those documented for
temporaryFile()
. -
TempFile::getPath()
Return the path to the temporary file, this is mainly intended to be used when interacting with the file outside of PHP.
-
TempFile::open(string $mode)
Open the file for reading/writing according to the supplied mode, defaults to
r+
. Returns an\SplFileObject
that maybe used to manipulate the contents of the temporary file. -
TempFile::keep(string $newPath)
Persist the temporary file into permanent file at the path specified, returns a new
\SplFileInfo
representing the new file. -
TempFile::copyTo(resource $stream)
Copy the contents of the file into the supplied stream.
-
TempFile::release()
Removes the temporary file from disk.