2015-08-16 19:59:23 +02:00
|
|
|
<?php
|
|
|
|
|
2018-09-25 13:30:50 +02:00
|
|
|
namespace BookStack\Actions;
|
|
|
|
|
|
|
|
use BookStack\Auth\User;
|
2020-11-22 01:17:45 +01:00
|
|
|
use BookStack\Entities\Models\Entity;
|
2018-09-25 13:30:50 +02:00
|
|
|
use BookStack\Model;
|
2020-11-08 01:03:19 +01:00
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
2021-03-07 23:24:05 +01:00
|
|
|
use Illuminate\Database\Eloquent\Relations\MorphTo;
|
2020-11-20 20:33:11 +01:00
|
|
|
use Illuminate\Support\Str;
|
2015-08-16 19:59:23 +02:00
|
|
|
|
|
|
|
/**
|
2020-11-08 01:03:19 +01:00
|
|
|
* @property string $type
|
2021-06-26 17:23:15 +02:00
|
|
|
* @property User $user
|
2019-09-19 19:03:17 +02:00
|
|
|
* @property Entity $entity
|
2020-11-08 01:03:19 +01:00
|
|
|
* @property string $detail
|
2019-09-19 19:03:17 +02:00
|
|
|
* @property string $entity_type
|
2021-06-26 17:23:15 +02:00
|
|
|
* @property int $entity_id
|
|
|
|
* @property int $user_id
|
2015-08-16 19:59:23 +02:00
|
|
|
*/
|
|
|
|
class Activity extends Model
|
|
|
|
{
|
2015-08-30 12:47:58 +02:00
|
|
|
/**
|
|
|
|
* Get the entity for this activity.
|
|
|
|
*/
|
2021-03-07 23:24:05 +01:00
|
|
|
public function entity(): MorphTo
|
2015-08-16 19:59:23 +02:00
|
|
|
{
|
2018-01-28 17:58:52 +01:00
|
|
|
if ($this->entity_type === '') {
|
|
|
|
$this->entity_type = null;
|
|
|
|
}
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2016-02-28 20:03:04 +01:00
|
|
|
return $this->morphTo('entity');
|
2015-08-16 19:59:23 +02:00
|
|
|
}
|
|
|
|
|
2015-08-30 12:47:58 +02:00
|
|
|
/**
|
|
|
|
* Get the user this activity relates to.
|
|
|
|
*/
|
2020-11-08 01:03:19 +01:00
|
|
|
public function user(): BelongsTo
|
2015-08-16 19:59:23 +02:00
|
|
|
{
|
2016-05-01 22:20:50 +02:00
|
|
|
return $this->belongsTo(User::class);
|
2015-08-16 19:59:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2020-11-08 01:03:19 +01:00
|
|
|
* Returns text from the language files, Looks up by using the activity key.
|
2015-08-16 19:59:23 +02:00
|
|
|
*/
|
2020-11-08 01:03:19 +01:00
|
|
|
public function getText(): string
|
2015-08-16 19:59:23 +02:00
|
|
|
{
|
2020-11-08 01:03:19 +01:00
|
|
|
return trans('activities.' . $this->type);
|
2015-08-16 19:59:23 +02:00
|
|
|
}
|
|
|
|
|
2020-11-20 20:33:11 +01:00
|
|
|
/**
|
|
|
|
* Check if this activity is intended to be for an entity.
|
|
|
|
*/
|
|
|
|
public function isForEntity(): bool
|
|
|
|
{
|
|
|
|
return Str::startsWith($this->type, [
|
2021-06-26 17:23:15 +02:00
|
|
|
'page_', 'chapter_', 'book_', 'bookshelf_',
|
2020-11-20 20:33:11 +01:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2015-08-30 12:47:58 +02:00
|
|
|
/**
|
|
|
|
* Checks if another Activity matches the general information of another.
|
|
|
|
*/
|
2021-10-26 23:04:18 +02:00
|
|
|
public function isSimilarTo(self $activityB): bool
|
2018-01-28 17:58:52 +01:00
|
|
|
{
|
2020-11-08 01:03:19 +01:00
|
|
|
return [$this->type, $this->entity_type, $this->entity_id] === [$activityB->type, $activityB->entity_type, $activityB->entity_id];
|
2015-08-30 12:47:58 +02:00
|
|
|
}
|
2015-08-16 19:59:23 +02:00
|
|
|
}
|