109 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| 
 | |
| namespace BookStack\Uploads;
 | |
| 
 | |
| use BookStack\App\Model;
 | |
| use BookStack\Entities\Models\Entity;
 | |
| use BookStack\Entities\Models\Page;
 | |
| use BookStack\Permissions\Models\JointPermission;
 | |
| use BookStack\Permissions\PermissionApplicator;
 | |
| use BookStack\Users\Models\HasCreatorAndUpdater;
 | |
| use BookStack\Users\Models\User;
 | |
| use Illuminate\Database\Eloquent\Builder;
 | |
| use Illuminate\Database\Eloquent\Factories\HasFactory;
 | |
| use Illuminate\Database\Eloquent\Relations\BelongsTo;
 | |
| use Illuminate\Database\Eloquent\Relations\HasMany;
 | |
| 
 | |
| /**
 | |
|  * @property int    $id
 | |
|  * @property string $name
 | |
|  * @property string $path
 | |
|  * @property string $extension
 | |
|  * @property ?Page  $page
 | |
|  * @property bool   $external
 | |
|  * @property int    $uploaded_to
 | |
|  * @property User   $updatedBy
 | |
|  * @property User   $createdBy
 | |
|  *
 | |
|  * @method static Entity|Builder visible()
 | |
|  */
 | |
| class Attachment extends Model
 | |
| {
 | |
|     use HasCreatorAndUpdater;
 | |
|     use HasFactory;
 | |
| 
 | |
|     protected $fillable = ['name', 'order'];
 | |
|     protected $hidden = ['path', 'page'];
 | |
|     protected $casts = [
 | |
|         'external' => 'bool',
 | |
|     ];
 | |
| 
 | |
|     /**
 | |
|      * Get the downloadable file name for this upload.
 | |
|      */
 | |
|     public function getFileName(): string
 | |
|     {
 | |
|         if (str_contains($this->name, '.')) {
 | |
|             return $this->name;
 | |
|         }
 | |
| 
 | |
|         return $this->name . '.' . $this->extension;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the page this file was uploaded to.
 | |
|      */
 | |
|     public function page(): BelongsTo
 | |
|     {
 | |
|         return $this->belongsTo(Page::class, 'uploaded_to');
 | |
|     }
 | |
| 
 | |
|     public function jointPermissions(): HasMany
 | |
|     {
 | |
|         return $this->hasMany(JointPermission::class, 'entity_id', 'uploaded_to')
 | |
|             ->where('joint_permissions.entity_type', '=', 'page');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the url of this file.
 | |
|      */
 | |
|     public function getUrl($openInline = false): string
 | |
|     {
 | |
|         if ($this->external && !str_starts_with($this->path, 'http')) {
 | |
|             return $this->path;
 | |
|         }
 | |
| 
 | |
|         return url('/attachments/' . $this->id . ($openInline ? '?open=true' : ''));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Generate a HTML link to this attachment.
 | |
|      */
 | |
|     public function htmlLink(): string
 | |
|     {
 | |
|         return '<a target="_blank" href="' . e($this->getUrl()) . '">' . e($this->name) . '</a>';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Generate a markdown link to this attachment.
 | |
|      */
 | |
|     public function markdownLink(): string
 | |
|     {
 | |
|         return '[' . $this->name . '](' . $this->getUrl() . ')';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Scope the query to those attachments that are visible based upon related page permissions.
 | |
|      */
 | |
|     public function scopeVisible(): Builder
 | |
|     {
 | |
|         $permissions = app()->make(PermissionApplicator::class);
 | |
| 
 | |
|         return $permissions->restrictPageRelationQuery(
 | |
|             self::query(),
 | |
|             'attachments',
 | |
|             'uploaded_to'
 | |
|         );
 | |
|     }
 | |
| }
 |