File "FcmToken.php"

Full Path: /home/trinadezambia/public_html/admin_panel/app/Models/FcmToken.php
File size: 2.01 KB
MIME-type: text/x-php
Charset: utf-8

<?php

declare(strict_types=1);

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Builder;

final class FcmToken extends Model
{
    use HasFactory;

    /**
     * The attributes that are mass assignable.
     *
     * @var array<int, string>
     */
    protected $fillable = [
        'user_id',
        'fcm_token',
        'device_type',
        'device_id',
        'last_used_at',
    ];

    /**
     * The attributes that should be cast.
     *
     * @var array<string, string>
     */
    protected $casts = [
        'last_used_at' => 'datetime',
        'created_at' => 'datetime',
        'updated_at' => 'datetime',
    ];

    /**
     * Get the user that owns the FCM token.
     *
     * @return BelongsTo
     */
    public function user(): BelongsTo
    {
        return $this->belongsTo(User::class);
    }

    /**
     * Scope a query to only include active tokens. (No soft deletes)
     *
     * @param Builder $query
     * @return Builder
     */
    public function scopeByDeviceType(Builder $query, string $deviceType): Builder
    {
        return $query->where('device_type', $deviceType);
    }

    /**
     * Scope a query to filter by user.
     *
     * @param Builder $query
     * @param int $userId
     * @return Builder
     */
    public function scopeForUser(Builder $query, int $userId): Builder
    {
        return $query->where('user_id', $userId);
    }

    /**
     * Scope a query to get tokens for multiple users.
     *
     * @param Builder $query
     * @param array<int> $userIds
     * @return Builder
     */
    public function scopeForUsers(Builder $query, array $userIds): Builder
    {
        return $query->whereIn('user_id', $userIds);
    }

    /**
     * Update the last_used_at timestamp.
     *
     * @return bool
     */
    public function touchLastUsed(): bool
    {
        return $this->update(['last_used_at' => now()]);
    }
}