2018-09-25 12:30:50 +01:00
|
|
|
<?php namespace BookStack\Uploads;
|
|
|
|
|
|
|
|
use BookStack\Entities\Page;
|
|
|
|
use BookStack\Ownable;
|
2016-10-09 18:58:22 +01:00
|
|
|
|
2020-09-13 18:29:48 +01:00
|
|
|
/**
|
|
|
|
* @property int id
|
|
|
|
* @property string name
|
|
|
|
* @property string path
|
|
|
|
* @property string extension
|
|
|
|
* @property bool external
|
|
|
|
*/
|
2016-11-12 14:12:26 +00:00
|
|
|
class Attachment extends Ownable
|
2016-10-09 18:58:22 +01:00
|
|
|
{
|
|
|
|
protected $fillable = ['name', 'order'];
|
|
|
|
|
2016-10-23 13:36:45 +01:00
|
|
|
/**
|
|
|
|
* Get the downloadable file name for this upload.
|
|
|
|
* @return mixed|string
|
|
|
|
*/
|
|
|
|
public function getFileName()
|
|
|
|
{
|
2019-09-13 23:58:40 +01:00
|
|
|
if (strpos($this->name, '.') !== false) {
|
2018-01-28 16:58:52 +00:00
|
|
|
return $this->name;
|
|
|
|
}
|
2016-10-23 13:36:45 +01:00
|
|
|
return $this->name . '.' . $this->extension;
|
|
|
|
}
|
|
|
|
|
2016-10-09 18:58:22 +01:00
|
|
|
/**
|
|
|
|
* Get the page this file was uploaded to.
|
2018-09-25 18:00:40 +01:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
2016-10-09 18:58:22 +01:00
|
|
|
*/
|
|
|
|
public function page()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Page::class, 'uploaded_to');
|
|
|
|
}
|
|
|
|
|
2016-10-10 20:30:27 +01:00
|
|
|
/**
|
|
|
|
* Get the url of this file.
|
|
|
|
*/
|
2020-06-30 22:12:45 +01:00
|
|
|
public function getUrl(): string
|
2016-10-10 20:30:27 +01:00
|
|
|
{
|
2018-05-20 11:06:10 +01:00
|
|
|
if ($this->external && strpos($this->path, 'http') !== 0) {
|
|
|
|
return $this->path;
|
|
|
|
}
|
2019-08-04 14:26:39 +01:00
|
|
|
return url('/attachments/' . $this->id);
|
2016-10-10 20:30:27 +01:00
|
|
|
}
|
2020-07-28 10:45:28 +01:00
|
|
|
|
2020-09-13 18:29:48 +01:00
|
|
|
/**
|
|
|
|
* Generate a HTML link to this attachment.
|
|
|
|
*/
|
2020-07-28 10:45:28 +01:00
|
|
|
public function htmlLink(): string
|
|
|
|
{
|
|
|
|
return '<a target="_blank" href="'.e($this->getUrl()).'">'.e($this->name).'</a>';
|
|
|
|
}
|
|
|
|
|
2020-09-13 18:29:48 +01:00
|
|
|
/**
|
|
|
|
* Generate a markdown link to this attachment.
|
|
|
|
*/
|
2020-07-28 10:45:28 +01:00
|
|
|
public function markdownLink(): string
|
|
|
|
{
|
2020-09-13 18:29:48 +01:00
|
|
|
return '['. $this->name .']('. $this->getUrl() .')';
|
2020-07-28 10:45:28 +01:00
|
|
|
}
|
2016-10-09 18:58:22 +01:00
|
|
|
}
|