⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.19
Server IP:
178.33.27.10
Server:
Linux cpanel.dev-unit.com 3.10.0-1160.108.1.el7.x86_64 #1 SMP Thu Jan 25 16:17:31 UTC 2024 x86_64
Server Software:
Apache/2.4.57 (Unix) OpenSSL/1.0.2k-fips
PHP Version:
8.2.11
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
home
/
id
/
dalily.dev-unit.com
/
app
/
Models
/
View File Name :
ThreadParticipant.php
<?php /* * LaraClassifier - Classified Ads Web Application * Copyright (c) BeDigit. All Rights Reserved * * Website: https://laraclassifier.com * Author: Mayeul Akpovi (BeDigit - https://bedigit.com) * * LICENSE * ------- * This software is provided under a license agreement and may only be used or copied * in accordance with its terms, including the inclusion of the above copyright notice. * As this software is sold exclusively on CodeCanyon, * please review the full license details here: https://codecanyon.net/licenses/standard */ namespace App\Models; use App\Casts\DateTimeCast; use App\Casts\NullableDateTimeCast; use App\Helpers\Common\Date; use App\Http\Controllers\Web\Admin\Panel\Library\Traits\Models\Crud; use App\Models\Traits\Common\AppendsTrait; use Illuminate\Database\Eloquent\Casts\Attribute; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Relations\BelongsTo; use Illuminate\Database\Eloquent\SoftDeletes; use Illuminate\Notifications\Notifiable; class ThreadParticipant extends BaseModel { use SoftDeletes, Crud, AppendsTrait, Notifiable, HasFactory; /** * The table associated with the model. * * @var string */ protected $table = 'threads_participants'; /** * @var array<int, string> */ protected $appends = ['created_at_formatted']; /** * The attributes that aren't mass assignable. * * @var array<int, string> */ protected $guarded = ['id']; /** * The attributes that are mass assignable. * * @var array<int, string> */ protected $fillable = [ 'thread_id', 'user_id', 'last_read', 'is_important', ]; /* |-------------------------------------------------------------------------- | FUNCTIONS |-------------------------------------------------------------------------- */ /** * Get the attributes that should be cast. * * @return array<string, string> */ protected function casts(): array { return [ 'created_at' => DateTimeCast::class, 'updated_at' => DateTimeCast::class, 'deleted_at' => NullableDateTimeCast::class, ]; } /* |-------------------------------------------------------------------------- | RELATIONS |-------------------------------------------------------------------------- */ public function thread(): BelongsTo { return $this->belongsTo(Thread::class, 'thread_id', 'id'); } public function user(): BelongsTo { return $this->belongsTo(User::class, 'user_id'); } /* |-------------------------------------------------------------------------- | SCOPES |-------------------------------------------------------------------------- */ /* |-------------------------------------------------------------------------- | ACCESSORS | MUTATORS |-------------------------------------------------------------------------- */ protected function createdAtFormatted(): Attribute { return Attribute::make( get: fn () => Date::customFromNow($this->created_at ?? null), ); } /* |-------------------------------------------------------------------------- | OTHER PRIVATE METHODS |-------------------------------------------------------------------------- */ }