2024-05-15 00:31:24 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
2024-05-31 17:44:52 -04:00
|
|
|
use App\Models\Scopes\DisabledScope;
|
2024-07-26 09:35:09 -04:00
|
|
|
use App\Models\Scopes\PublishedScope;
|
2024-05-15 00:31:24 -04:00
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
2024-08-29 15:46:10 -04:00
|
|
|
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
|
2024-07-26 02:19:42 -04:00
|
|
|
use Illuminate\Database\Eloquent\Relations\HasMany;
|
2024-05-15 00:31:24 -04:00
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
|
2024-07-26 02:19:42 -04:00
|
|
|
/**
|
|
|
|
* @property int $id
|
|
|
|
* @property int $mod_id
|
|
|
|
* @property string $version
|
|
|
|
*/
|
2024-05-15 00:31:24 -04:00
|
|
|
class ModVersion extends Model
|
|
|
|
{
|
|
|
|
use HasFactory, SoftDeletes;
|
|
|
|
|
2024-07-20 19:52:36 -04:00
|
|
|
/**
|
|
|
|
* Post boot method to configure the model.
|
|
|
|
*/
|
2024-05-31 17:44:52 -04:00
|
|
|
protected static function booted(): void
|
|
|
|
{
|
|
|
|
static::addGlobalScope(new DisabledScope);
|
2024-07-26 09:35:09 -04:00
|
|
|
static::addGlobalScope(new PublishedScope);
|
2024-05-31 17:44:52 -04:00
|
|
|
}
|
|
|
|
|
2024-07-20 19:52:36 -04:00
|
|
|
/**
|
|
|
|
* The relationship between a mod version and mod.
|
|
|
|
*/
|
2024-05-15 00:31:24 -04:00
|
|
|
public function mod(): BelongsTo
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Mod::class);
|
|
|
|
}
|
|
|
|
|
2024-07-26 02:19:42 -04:00
|
|
|
/**
|
|
|
|
* The relationship between a mod version and its dependencies.
|
|
|
|
*/
|
2024-08-29 15:46:10 -04:00
|
|
|
public function dependencies(): HasMany
|
2024-07-26 02:19:42 -04:00
|
|
|
{
|
2024-08-29 15:46:10 -04:00
|
|
|
return $this->hasMany(ModDependency::class);
|
|
|
|
}
|
2024-08-22 17:04:07 -04:00
|
|
|
|
2024-08-29 15:46:10 -04:00
|
|
|
/**
|
|
|
|
* The relationship between a mod version and its resolved dependencies.
|
|
|
|
*/
|
|
|
|
public function resolvedDependencies(): BelongsToMany
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(ModVersion::class, 'mod_resolved_dependencies', 'mod_version_id', 'resolved_mod_version_id')
|
|
|
|
->withPivot('dependency_id')
|
|
|
|
->withTimestamps();
|
|
|
|
}
|
2024-08-22 17:04:07 -04:00
|
|
|
|
2024-08-29 15:46:10 -04:00
|
|
|
/**
|
|
|
|
* The relationship between a mod version and its each of it's resolved dependencies' latest versions.
|
|
|
|
*/
|
|
|
|
public function latestResolvedDependencies(): BelongsToMany
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(ModVersion::class, 'mod_resolved_dependencies', 'mod_version_id', 'resolved_mod_version_id')
|
|
|
|
->withPivot('dependency_id')
|
|
|
|
->join('mod_versions as latest_versions', function ($join) {
|
|
|
|
$join->on('latest_versions.id', '=', 'mod_versions.id')
|
|
|
|
->whereRaw('latest_versions.version = (SELECT MAX(mv.version) FROM mod_versions mv WHERE mv.mod_id = mod_versions.mod_id)');
|
|
|
|
})
|
|
|
|
->with('mod:id,name,slug')
|
|
|
|
->withTimestamps();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The relationship between a mod version and each of its SPT versions' latest version.
|
|
|
|
* Hint: Be sure to call `->first()` on this to get the actual instance.
|
|
|
|
*/
|
|
|
|
public function latestSptVersion(): BelongsToMany
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(SptVersion::class, 'mod_version_spt_version')
|
|
|
|
->orderBy('version', 'desc')
|
|
|
|
->limit(1);
|
2024-07-26 02:19:42 -04:00
|
|
|
}
|
|
|
|
|
2024-07-20 19:52:36 -04:00
|
|
|
/**
|
2024-08-29 15:46:10 -04:00
|
|
|
* The relationship between a mod version and its SPT versions.
|
2024-07-20 19:52:36 -04:00
|
|
|
*/
|
2024-08-29 15:46:10 -04:00
|
|
|
public function sptVersions(): BelongsToMany
|
2024-05-15 00:31:24 -04:00
|
|
|
{
|
2024-08-29 15:46:10 -04:00
|
|
|
return $this->belongsToMany(SptVersion::class, 'mod_version_spt_version')
|
|
|
|
->orderByDesc('version');
|
2024-05-17 17:11:54 -04:00
|
|
|
}
|
2024-05-15 00:31:24 -04:00
|
|
|
}
|