67 lines
1.9 KiB
PHP
67 lines
1.9 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace App\Console\Commands;
|
||
|
|
||
|
use Carbon\Carbon;
|
||
|
use Illuminate\Console\Command;
|
||
|
use Illuminate\Support\Facades\Config;
|
||
|
|
||
|
use App\Models\{Site,Supplier,User};
|
||
|
|
||
|
class SupplierAccountSync extends Command
|
||
|
{
|
||
|
/**
|
||
|
* The name and signature of the console command.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $signature = 'supplier:account:sync'
|
||
|
.' {siteid : Site ID}'
|
||
|
.' {supplier : Supplier Name}'
|
||
|
.' {--f|forceprod : Force Prod API on dev environment}';
|
||
|
|
||
|
/**
|
||
|
* The console command description.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $description = 'Sync accounts with a supplier';
|
||
|
|
||
|
/**
|
||
|
* Execute the console command.
|
||
|
*
|
||
|
* @return int
|
||
|
*/
|
||
|
public function handle()
|
||
|
{
|
||
|
Config::set('site',Site::findOrFail($this->argument('siteid')));
|
||
|
$so = Supplier::where('name',$this->argument('supplier'))->singleOrFail();
|
||
|
|
||
|
foreach ($so->API($this->option('forceprod'))->getCustomers(['fetchall'=>true]) as $customer) {
|
||
|
// Check if we have this customer already (by ID)
|
||
|
if ($so->users->where('pivot.id',$customer->id)->count()) {
|
||
|
$this->info(sprintf('User already linked (%s:%s)',$customer->id,$customer->email));
|
||
|
|
||
|
} elseif ($x=User::where('email',$customer->email)->single()) {
|
||
|
//dump($x->suppliers->first());
|
||
|
if ($x->suppliers->count()) {
|
||
|
$this->alert(sprintf('User [%d:%s] already linked to this supplier with ID (%s)',$customer->id,$customer->email,$x->suppliers->first()->pivot->id));
|
||
|
|
||
|
} else {
|
||
|
$this->warn(sprintf('User [%d:%s] has same email (%s:%s) - Linked',$x->id,$x->email,$customer->id,$customer->email));
|
||
|
|
||
|
$so->users()->syncWithoutDetaching([
|
||
|
$x->id => [
|
||
|
'id'=>$customer->id,
|
||
|
'site_id'=>$x->site_id, // @todo See if we can have this handled automatically
|
||
|
'created_at'=>Carbon::create($customer->date_added),
|
||
|
]
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
} else {
|
||
|
$this->error(sprintf('User doesnt exist with email (%s)',$customer->email));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|