From b7a7bea0871eedeaab1721ff272f3a450761c4b8 Mon Sep 17 00:00:00 2001 From: Nicolas MURE Date: Fri, 28 Jun 2019 17:05:36 +0200 Subject: [PATCH] Do not automatically create the base directory for Local adapter Related to https://github.com/KnpLabs/Gaufrette/issues/618 We throw an exception when building the adapter if the specified base directory does not exist. The write methods can still create sub directories (eg /base/my/very/deep/dir), however the /base directory have to be present. The developer should create this directory on its own before using the adapter. --- spec/Gaufrette/Adapter/LocalSpec.php | 7 +++++++ src/Gaufrette/Adapter/Local.php | 7 ++++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/spec/Gaufrette/Adapter/LocalSpec.php b/spec/Gaufrette/Adapter/LocalSpec.php index 9066430c8..230f8c189 100644 --- a/spec/Gaufrette/Adapter/LocalSpec.php +++ b/spec/Gaufrette/Adapter/LocalSpec.php @@ -33,6 +33,13 @@ function it_is_a_mime_type_provider() $this->shouldHaveType('Gaufrette\Adapter\MimeTypeProvider'); } + function it_throws_when_the_base_directory_does_not_exist() + { + $this->beConstructedWith('/do-no-exists'); + + $this->shouldThrow(StorageFailure::class)->duringInstantiation(); + } + function it_gets_the_file_mime_type() { $this->mimeType('filename')->shouldReturn('text/plain'); diff --git a/src/Gaufrette/Adapter/Local.php b/src/Gaufrette/Adapter/Local.php index eb30227d1..ccdd64973 100644 --- a/src/Gaufrette/Adapter/Local.php +++ b/src/Gaufrette/Adapter/Local.php @@ -23,7 +23,6 @@ class Local implements Adapter, MimeTypeProvider { protected $directory; - private $create; private $mode; /** @@ -39,6 +38,12 @@ public function __construct($directory, $mode = 0777) if (is_link($this->directory)) { $this->directory = realpath($this->directory); } + + if (!is_dir($this->directory)) { + throw new StorageFailure( + sprintf('Directory "%s" does not exist.', $directory) + ); + } } /**