forge/app/Models/Mod.php
2024-06-01 23:04:06 -04:00

112 lines
3.1 KiB
PHP

<?php
namespace App\Models;
use App\Models\Scopes\DisabledScope;
use Illuminate\Database\Eloquent\Casts\Attribute;
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\Database\Eloquent\SoftDeletes;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Str;
/**
* @property string $slug
*/
class Mod extends Model
{
use HasFactory, SoftDeletes;
protected $fillable = [
'user_id',
'name',
'slug',
'description',
'license_id',
'source_code_link',
];
protected static function booted(): void
{
static::addGlobalScope(new DisabledScope);
}
protected function slug(): Attribute
{
return Attribute::make(
get: fn (string $value) => strtolower($value),
set: fn (string $value) => Str::slug($value),
);
}
public function user(): BelongsTo
{
return $this->belongsTo(User::class);
}
public function license(): BelongsTo
{
return $this->belongsTo(License::class);
}
public function versions(): HasMany
{
return $this->hasMany(ModVersion::class);
}
public function scopeWithTotalDownloads($query)
{
return $query->addSelect(['total_downloads' => ModVersion::selectRaw('SUM(downloads) AS total_downloads')
->whereColumn('mod_id', 'mods.id'),
]);
}
public function latestSptVersion(): BelongsTo
{
return $this->belongsTo(ModVersion::class, 'latest_spt_version_id');
}
public function scopeWithLatestSptVersion($query)
{
return $query
->addSelect(['latest_spt_version_id' => ModVersion::select('id')
->whereColumn('mod_id', 'mods.id')
->orderByDesc(
SptVersion::select('version')
->whereColumn('mod_versions.spt_version_id', 'spt_versions.id')
->orderByDesc('version')
->take(1),
)
->orderByDesc('version')
->take(1),
])
->havingNotNull('latest_spt_version_id')
->with(['latestSptVersion', 'latestSptVersion.sptVersion']);
}
public function lastUpdatedVersion(): BelongsTo
{
return $this->belongsTo(ModVersion::class, 'last_updated_spt_version_id');
}
public function scopeWithLastUpdatedVersion($query)
{
return $query
->addSelect(['last_updated_spt_version_id' => ModVersion::select('id')
->whereColumn('mod_id', 'mods.id')
->orderByDesc('updated_at')
->take(1),
])
->orderByDesc(
ModVersion::select('updated_at')
->whereColumn('mod_id', 'mods.id')
->orderByDesc('updated_at')
->take(1)
)
->havingNotNull('last_updated_spt_version_id')
->with(['lastUpdatedVersion', 'lastUpdatedVersion.sptVersion']);
}
}