2023-01-20 08:05:12 +00:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Jobs\Module;
|
|
|
|
|
|
|
|
|
|
use App\Models\Module;
|
2023-02-12 18:21:09 +00:00
|
|
|
|
use Exception;
|
2023-01-20 08:05:12 +00:00
|
|
|
|
use Illuminate\Bus\Queueable;
|
|
|
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
|
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
|
|
|
use Illuminate\Queue\SerializesModels;
|
2023-02-12 18:21:09 +00:00
|
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
|
|
use Illuminate\Support\Facades\Log;
|
2023-01-20 08:05:12 +00:00
|
|
|
|
|
|
|
|
|
class DispatchFetchModuleJob implements ShouldQueue
|
|
|
|
|
{
|
|
|
|
|
use InteractsWithQueue, Queueable, SerializesModels;
|
|
|
|
|
|
2023-02-12 18:21:09 +00:00
|
|
|
|
protected ?Module $module;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Create a new job instance.
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function __construct(Module $module = null)
|
|
|
|
|
{
|
|
|
|
|
$this->module = $module;
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-20 08:05:12 +00:00
|
|
|
|
/**
|
|
|
|
|
* Execute the job.
|
|
|
|
|
*/
|
|
|
|
|
public function handle(): void
|
|
|
|
|
{
|
2023-02-12 18:27:59 +00:00
|
|
|
|
if (! $this->module) {
|
2023-02-12 18:21:09 +00:00
|
|
|
|
(new Module)->whereNotNull('url')->chunk(100, function ($modules) {
|
|
|
|
|
foreach ($modules as $module) {
|
|
|
|
|
dispatch(new self($module));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($this->module) {
|
|
|
|
|
$module = $this->module;
|
|
|
|
|
|
|
|
|
|
$servers = [];
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
$response = $module->http()->get('remote');
|
|
|
|
|
} catch (Exception $e) {
|
2023-02-12 18:27:59 +00:00
|
|
|
|
Log::debug('无法连接到模块 - down: '.$e->getMessage());
|
2023-02-12 18:21:09 +00:00
|
|
|
|
|
|
|
|
|
// 如果模块状态不为 down,则更新为 down
|
|
|
|
|
if ($module->status !== 'down') {
|
|
|
|
|
$module->status = 'down';
|
|
|
|
|
$module->save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($response->successful()) {
|
|
|
|
|
// 如果模块状态不为 up,则更新为 up
|
|
|
|
|
if ($module->status !== 'up') {
|
|
|
|
|
$module->status = 'up';
|
2023-02-12 18:27:59 +00:00
|
|
|
|
Log::debug('模块状态更新为 up: '.$module->name);
|
2023-02-12 18:21:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$json = $response->json();
|
|
|
|
|
|
|
|
|
|
if (isset($json['servers']) && is_array($json['servers'])) {
|
|
|
|
|
// 只保留 name, status, meta
|
|
|
|
|
$servers = array_merge($servers, array_map(function ($server) use ($module) {
|
|
|
|
|
return [
|
|
|
|
|
'name' => $server['name'],
|
|
|
|
|
'status' => $server['status'],
|
|
|
|
|
'meta' => $server['meta'] ?? [],
|
|
|
|
|
'created_at' => $server['created_at'] ?? now(),
|
|
|
|
|
'updated_at' => $server['updated_at'] ?? now(),
|
|
|
|
|
'module' => [
|
|
|
|
|
'id' => $module->id,
|
|
|
|
|
'name' => $module->name,
|
|
|
|
|
],
|
|
|
|
|
];
|
|
|
|
|
}, $json['servers']));
|
|
|
|
|
|
|
|
|
|
// broadcast(new Servers($servers));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
// if module return maintenance, then set module status to maintenance
|
|
|
|
|
$status = $response->status();
|
|
|
|
|
if ($status == 503 || $status == 429 || $status == 502) {
|
|
|
|
|
$module->status = 'maintenance';
|
|
|
|
|
} else {
|
|
|
|
|
$module->status = 'down';
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-12 18:27:59 +00:00
|
|
|
|
Log::debug('模块状态更新为 '.$module->status.': '.$module->name);
|
2023-02-12 18:21:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$module->save();
|
|
|
|
|
|
|
|
|
|
// if local
|
|
|
|
|
if (config('app.env') === 'local') {
|
2023-02-12 18:27:59 +00:00
|
|
|
|
Cache::forever('module:'.$module->id.':servers', $servers);
|
2023-02-12 18:21:09 +00:00
|
|
|
|
} else {
|
2023-02-12 18:27:59 +00:00
|
|
|
|
Cache::put('module:'.$module->id.':servers', $servers, now()->addMinutes(10));
|
2023-01-20 08:05:12 +00:00
|
|
|
|
}
|
2023-02-12 18:21:09 +00:00
|
|
|
|
}
|
2023-01-20 08:05:12 +00:00
|
|
|
|
}
|
|
|
|
|
}
|