<?php namespace BookStack\Services;
+use BookStack\Exceptions\ImageUploadException;
use BookStack\Image;
use BookStack\User;
+use Exception;
+use Intervention\Image\Exception\NotSupportedException;
use Intervention\Image\ImageManager;
use Illuminate\Contracts\Filesystem\Factory as FileSystem;
use Illuminate\Contracts\Filesystem\Filesystem as FileSystemInstance;
* @param string $imageData
* @param string $type
* @return Image
+ * @throws ImageUploadException
*/
private function saveNew($imageName, $imageData, $type)
{
}
$fullPath = $imagePath . $imageName;
- $storage->put($fullPath, $imageData);
+ try {
+ $storage->put($fullPath, $imageData);
+ } catch (Exception $e) {
+ throw new ImageUploadException('Image Path ' . $fullPath . ' is not writable by the server.');
+ }
- $userId = auth()->user()->id;
- $image = Image::forceCreate([
+ $imageDetails = [
'name' => $imageName,
'path' => $fullPath,
'url' => $this->getPublicUrl($fullPath),
- 'type' => $type,
- 'created_by' => $userId,
- 'updated_by' => $userId
- ]);
+ 'type' => $type
+ ];
+
+ if (auth()->user() && auth()->user()->id !== 0) {
+ $userId = auth()->user()->id;
+ $imageDetails['created_by'] = $userId;
+ $imageDetails['updated_by'] = $userId;
+ }
+
+ $image = Image::forceCreate($imageDetails);
return $image;
}
* Checks the cache then storage to avoid creating / accessing the filesystem on every check.
*
* @param Image $image
- * @param int $width
- * @param int $height
- * @param bool $keepRatio
+ * @param int $width
+ * @param int $height
+ * @param bool $keepRatio
* @return string
+ * @throws Exception
+ * @throws ImageUploadException
*/
public function getThumbnail(Image $image, $width = 220, $height = 220, $keepRatio = false)
{
return $this->getPublicUrl($thumbFilePath);
}
- // Otherwise create the thumbnail
- $thumb = $this->imageTool->make($storage->get($image->path));
+ try {
+ $thumb = $this->imageTool->make($storage->get($image->path));
+ } catch (Exception $e) {
+ if ($e instanceof \ErrorException || $e instanceof NotSupportedException) {
+ throw new ImageUploadException('The server cannot create thumbnails. Please check you have the GD PHP extension installed.');
+ } else {
+ throw $e;
+ }
+ }
+
if ($keepRatio) {
$thumb->resize($width, null, function ($constraint) {
$constraint->aspectRatio();
$imageName = str_replace(' ', '-', $user->name . '-gravatar.png');
$image = $this->saveNewFromUrl($url, 'user', $imageName);
$image->created_by = $user->id;
+ $image->updated_by = $user->id;
$image->save();
return $image;
}
{
if ($this->storageInstance !== null) return $this->storageInstance;
- $storageType = env('STORAGE_TYPE');
+ $storageType = config('filesystems.default');
$this->storageInstance = $this->fileSystem->disk($storageType);
return $this->storageInstance;
private function getPublicUrl($filePath)
{
if ($this->storageUrl === null) {
- $storageUrl = env('STORAGE_URL');
+ $storageUrl = config('filesystems.url');
// Get the standard public s3 url if s3 is set as storage type
- if ($storageUrl == false && env('STORAGE_TYPE') === 's3') {
+ if ($storageUrl == false && config('filesystems.default') === 's3') {
$storageDetails = config('filesystems.disks.s3');
$storageUrl = 'https://s3-' . $storageDetails['region'] . '.amazonaws.com/' . $storageDetails['bucket'];
}