2022-02-01 16:40:46 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models\Supplier;
|
|
|
|
|
2022-08-10 15:18:56 +10:00
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
|
2022-02-01 16:40:46 +11:00
|
|
|
use App\Interfaces\SupplierItem;
|
|
|
|
use App\Models\Product\Domain as ProductDomain;
|
|
|
|
use App\Models\TLD;
|
|
|
|
|
|
|
|
final class Domain extends Type implements SupplierItem
|
|
|
|
{
|
2022-06-30 23:51:20 +10:00
|
|
|
protected const category_name = 'Domain Name';
|
|
|
|
|
2022-02-01 16:40:46 +11:00
|
|
|
protected $table = 'supplier_domain';
|
|
|
|
|
|
|
|
/* INTERFACES */
|
|
|
|
|
|
|
|
public function getBillingIntervalAttribute(): int
|
|
|
|
{
|
|
|
|
return 4; // Yearly
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getNameAttribute(): string
|
|
|
|
{
|
|
|
|
return sprintf('%s: %s',$this->product_id,$this->tld->name);
|
|
|
|
}
|
|
|
|
|
2022-06-30 23:51:20 +10:00
|
|
|
public function products()
|
2022-04-02 18:06:34 +11:00
|
|
|
{
|
2022-06-30 23:51:20 +10:00
|
|
|
return $this->hasMany(ProductDomain::class,'supplier_item_id','id');
|
2022-04-02 18:06:34 +11:00
|
|
|
}
|
|
|
|
|
2022-08-10 15:18:56 +10:00
|
|
|
/* STATIC */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine the owner of the name servers used for the domain
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function nameserver_name(Collection $nameservers): string
|
|
|
|
{
|
|
|
|
foreach (config('nameservers') as $key => $ns) {
|
|
|
|
if ($nameservers->diff($ns)->count() < count($ns))
|
|
|
|
return $key;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'custom';
|
|
|
|
}
|
|
|
|
|
2022-02-01 16:40:46 +11:00
|
|
|
/* RELATIONS */
|
|
|
|
|
|
|
|
public function tld()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(TLD::class);
|
|
|
|
}
|
|
|
|
}
|