81 lines
2.4 KiB
PHP
81 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace App\Jobs;
|
|
|
|
use Carbon\Carbon;
|
|
use Illuminate\Bus\Queueable;
|
|
use Illuminate\Contracts\Queue\ShouldBeUnique;
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
use Illuminate\Foundation\Bus\Dispatchable;
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
use Illuminate\Queue\SerializesModels;
|
|
use Illuminate\Support\Facades\Config;
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
use App\Models\{Site,Supplier,TLD};
|
|
|
|
class SupplierDomainSync implements ShouldQueue
|
|
{
|
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
|
|
|
private const LOGKEY = 'JSD';
|
|
|
|
protected Site $site;
|
|
protected Supplier $supplier;
|
|
protected bool $forceprod;
|
|
|
|
/**
|
|
* Create a new job instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct(Site $site,Supplier $supplier,bool $forceprod=FALSE)
|
|
{
|
|
$this->site = $site;
|
|
$this->supplier = $supplier;
|
|
$this->forceprod = $forceprod;
|
|
|
|
Config::set('site',$site);
|
|
}
|
|
|
|
/**
|
|
* Execute the job.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function handle()
|
|
{
|
|
$registrar_id = ($x=$this->supplier->registrar()) ? $x->id : NULL;
|
|
|
|
foreach ($this->supplier->API($this->forceprod)->getDomains(['fetchall'=>true]) as $domain) {
|
|
// @todo See if we can find this domain by its ID
|
|
|
|
// Find this domain by it's name
|
|
if (! $to=TLD::domaintld($domain->domain_name)) {
|
|
Log::alert(sprintf('%s:Domain [%s] from (%s) is not in a TLD that we manage',self::LOGKEY,$this->supplier->name,$domain->domain_name));
|
|
|
|
} elseif (($domainpart=strtolower($to->domain_part($domain->domain_name))) && (($x=$to->domains->where('domain_name',$domainpart))->count() === 1)) {
|
|
$o = $x->pop();
|
|
$o->registrar_auth_password = $domain->auth_key;
|
|
$o->expire_at = Carbon::create($domain->expiry_date);
|
|
$o->registrar_account = $domain->account;
|
|
$o->registrar_username = '';
|
|
$o->registrar_ns = Supplier\Domain::nameserver_name($domain->nameservers());
|
|
if ($registrar_id)
|
|
$o->domain_registrar_id = $registrar_id;
|
|
|
|
if ($o->getDirty()) {
|
|
Log::info(sprintf('%s:Updating Domain [%s] from (%s)',self::LOGKEY,$domain->domain_name,$this->supplier->name));
|
|
$o->save();
|
|
|
|
} else {
|
|
Log::info(sprintf('%s:No Change to Domain [%s] from (%s)',self::LOGKEY,$domain->domain_name,$this->supplier->name));
|
|
}
|
|
|
|
// Alert an unmanaged name.
|
|
} else {
|
|
Log::alert(sprintf('%s:Domain [%s] from (%s) is not one managed in OSB',self::LOGKEY,$this->supplier->name,$domain->domain_name));
|
|
}
|
|
}
|
|
}
|
|
} |