Adding a command for my own needs

This commit is contained in:
Axel 2021-12-20 12:56:02 +01:00
parent 10ef2dd4e8
commit 74a7353b85
3 changed files with 124 additions and 3 deletions

2
.gitignore vendored
View file

@ -4,4 +4,4 @@ Homestead.json
Homestead.yaml
.env
.phpunit.result.cache
/node_modules
/node_modules

View file

@ -0,0 +1,114 @@
<?php
/**
* THIS COMMAND IS FOR MY OWN NEEDS ONLY
* IT SYNCS ALL THE TASKS FROM A DISTANT API
* IT IS PROBABLY WORTHLESS FOR YOU
*/
namespace App\Console\Commands;
use Illuminate\Console\Command;
class SyncCustomers extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'customers:sync';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Synchronize all customers';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
if (env('CMS_ENABLE_SYNC') != true) {
$this->error('Customers synchronisation is globally disabled.');
return null;
}
$this->line('Starting synchronisation');
$customers = $tasks = $contacts = [];
// Getting active customers
$opts = [
CURLOPT_POST => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_FOLLOWLOCATION => false,
CURLOPT_FAILONERROR => true,
CURLOPT_POSTFIELDS => [
'access' => env('CMS_API_ACCESS'),
'token' => env('CMS_API_TOKEN')
],
CURLOPT_URL => env('CMS_API_URL')
];
$ch = curl_init();
curl_setopt_array($ch, $opts);
if ($result = curl_exec($ch)) {
$customers = json_decode($result);
$bar = $this->output->createProgressBar(count($customers));
$bar->start();
// Getting existing tasks
$query = app('db')->select('SELECT * FROM tasks');
foreach ($query as $t) {
$tasks[$t->id] = preg_replace('~^https?://~', '', $t->host);
}
// Getting existing contacts
$contacts = app('db')->select('SELECT * FROM contacts');
// First we insert new customers
foreach($customers as $c) {
$bar->advance();
if (false === $key = array_search($c->domain, $tasks)) {
$ret = app('db')->insert('
INSERT INTO tasks (`host`, `type`, `params`, `creation_date`, `frequency`, `active`, `group_id`)
VALUES(:host, :type, :params, :creation_date, :frequency, :active, :group_id)
', [
'host' => 'https://'.$c->domain,
'type' => 'http',
'params' => 'propulsé par',
'creation_date' => date('Y-m-d H:i:s'),
'frequency' => 600,
'active' => 1,
'group_id' => $c->id
]);
}
}
// Then we delete old customers
foreach ($tasks as $t) {
}
}
}
}

View file

@ -4,6 +4,7 @@ namespace App\Console;
use Illuminate\Console\Scheduling\Schedule;
use Laravel\Lumen\Console\Kernel as ConsoleKernel;
use App\Console\Commands\SyncCustomers;
class Kernel extends ConsoleKernel
{
@ -13,7 +14,7 @@ class Kernel extends ConsoleKernel
* @var array
*/
protected $commands = [
//
SyncCustomers::class
];
/**
@ -24,6 +25,12 @@ class Kernel extends ConsoleKernel
*/
protected function schedule(Schedule $schedule)
{
//
/**
* This is for my own needs
* You may safely remove this scheduled task
*/
if (env('CMS_ENABLE_SYNC') == true) {
$schedule->command('customers:sync')->everyMinute();
}
}
}