You've already forked Atomcms-edit
4094f0fb14
HIGH: - Add missing import RadioSongRequestFormRequest (fixes crash on POST) - Add Purify XSS sanitization for article full_story - Fix duplicate radio API routes (/api/radio vs /api/radio/v2) - Add try-catch guards in InstallationController for missing records MEDIUM: - Fix N+1: eager load comments.user in ArticleController::show() - Fix GuestbookController authorization logic - Remove dead doSetup() method and duplicate route - Extract shared HasRadioDefaults trait (remove code duplication) - Use named routes in ForceStaffTwoFactorMiddleware - Fix WebsiteHelpCenterTicket::isOpen() (no permission leak) - Enable on WebsiteHelpCenterTicket (matches schema) - Replace WebsiteTeam::all()->pluck() with direct pluck() - Replace CatalogPage::all()->pluck() with direct pluck() - Replace WebsiteBadge::all() with direct pluck() - Add throttle middleware to guestbook store, logo-generator, radio embed LOW: - Remove unused imports - Remove dead /inertia-test route - Consolidate cache keys in RadioController
82 lines
2.5 KiB
PHP
Executable File
82 lines
2.5 KiB
PHP
Executable File
<?php
|
|
|
|
namespace App\Models\Help;
|
|
|
|
use App\Models\Concerns\BelongsToUser;
|
|
use App\Models\User;
|
|
use Carbon\Carbon;
|
|
use Illuminate\Database\Eloquent\Collection;
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
|
use Illuminate\Database\Eloquent\Relations\HasMany;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Stevebauman\Purify\Facades\Purify;
|
|
|
|
/**
|
|
* @property int $id
|
|
* @property int $user_id
|
|
* @property int $category_id
|
|
* @property string $subject
|
|
* @property string $content
|
|
* @property int $severity
|
|
* @property bool $open
|
|
* @property Carbon|null $created_at
|
|
* @property Carbon|null $updated_at
|
|
* @property-read string $content
|
|
* @property-read User|null $user
|
|
* @property-read WebsiteHelpCenterCategory|null $category
|
|
* @property-read Collection<int, WebsiteHelpCenterTicketReply> $replies
|
|
*
|
|
* @method static \Illuminate\Database\Eloquent\Builder<static>|WebsiteHelpCenterTicket orderBy($column, $direction = 'asc')
|
|
* @method static \Illuminate\Database\Eloquent\Builder<static>|WebsiteHelpCenterTicket where($column, $operator = null, $value = null)
|
|
* @method static \Illuminate\Database\Eloquent\Builder<static>|WebsiteHelpCenterTicket get($columns = ['*'])
|
|
* @method static \Illuminate\Database\Eloquent\Builder<static>|WebsiteHelpCenterTicket paginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
|
|
*/
|
|
class WebsiteHelpCenterTicket extends Model
|
|
{
|
|
use BelongsToUser;
|
|
use HasFactory;
|
|
|
|
#[\Override]
|
|
protected $guarded = ['id', 'created_at', 'updated_at', 'user_id', 'status', 'subject', 'category_id'];
|
|
|
|
#[\Override]
|
|
public $timestamps = true;
|
|
|
|
public function category(): BelongsTo
|
|
{
|
|
return $this->belongsTo(WebsiteHelpCenterCategory::class);
|
|
}
|
|
|
|
public function replies(): HasMany
|
|
{
|
|
return $this->hasMany(WebsiteHelpCenterTicketReply::class, 'ticket_id')->latest();
|
|
}
|
|
|
|
public function canDeleteTicket()
|
|
{
|
|
return $this->user_id === Auth::id() || hasPermission('delete_website_tickets');
|
|
}
|
|
|
|
public function canManageTicket()
|
|
{
|
|
return $this->user_id === Auth::id() || hasPermission('manage_website_tickets');
|
|
}
|
|
|
|
public function canCloseTicket()
|
|
{
|
|
return $this->user_id === Auth::id() || hasPermission('manage_website_tickets');
|
|
}
|
|
|
|
public function isOpen()
|
|
{
|
|
return (bool) $this->open;
|
|
}
|
|
|
|
public function getContentAttribute($value)
|
|
{
|
|
return Purify::clean($value);
|
|
}
|
|
}
|