<?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;
/**
* Saves a new image from an upload.
* @param UploadedFile $uploadedFile
- * @param string $type
+ * @param string $type
+ * @param int $uploadedTo
* @return mixed
+ * @throws ImageUploadException
*/
- public function saveNewFromUpload(UploadedFile $uploadedFile, $type)
+ public function saveNewFromUpload(UploadedFile $uploadedFile, $type, $uploadedTo = 0)
{
$imageName = $uploadedFile->getClientOriginalName();
$imageData = file_get_contents($uploadedFile->getRealPath());
- return $this->saveNew($imageName, $imageData, $type);
+ return $this->saveNew($imageName, $imageData, $type, $uploadedTo);
}
* @param string $imageName
* @param string $imageData
* @param string $type
+ * @param int $uploadedTo
* @return Image
+ * @throws ImageUploadException
*/
- private function saveNew($imageName, $imageData, $type)
+ private function saveNew($imageName, $imageData, $type, $uploadedTo = 0)
{
$storage = $this->getStorage();
- $secureUploads = Setting::get('app-secure-images');
+ $secureUploads = setting('app-secure-images');
$imageName = str_replace(' ', '-', $imageName);
if ($secureUploads) $imageName = str_random(16) . '-' . $imageName;
}
$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
- ]);
+ 'uploaded_to' => $uploadedTo
+ ];
+
+ 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();
*/
public function saveUserGravatar(User $user, $size = 500)
{
- if (!env('USE_GRAVATAR', false)) return false;
$emailHash = md5(strtolower(trim($user->email)));
$url = 'http://www.gravatar.com/avatar/' . $emailHash . '?s=' . $size . '&d=identicon';
$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();
- $user->avatar()->associate($image);
- $user->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'];
}