2023-03-02 09:55:33 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
|
|
|
|
use Closure;
|
2025-01-13 22:03:47 +11:00
|
|
|
use Config;
|
2023-03-03 16:07:11 +11:00
|
|
|
use GuzzleHttp\Client;
|
2025-01-13 22:03:47 +11:00
|
|
|
use Illuminate\Http\Request;
|
2023-03-02 09:55:33 +11:00
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
|
|
|
|
class CheckUpdate
|
|
|
|
{
|
2023-03-03 16:07:11 +11:00
|
|
|
private const UPDATE_SERVER = 'https://version.phpldapadmin.org';
|
|
|
|
private const UPDATE_TIME = 60*60*6;
|
|
|
|
|
2023-03-02 09:55:33 +11:00
|
|
|
/**
|
|
|
|
* Handle an incoming request.
|
|
|
|
*
|
2025-01-13 22:03:47 +11:00
|
|
|
* @param Request $request
|
|
|
|
* @param Closure $next
|
2023-03-02 09:55:33 +11:00
|
|
|
* @return mixed
|
|
|
|
*/
|
2025-01-13 22:03:47 +11:00
|
|
|
public function handle(Request $request, Closure $next): mixed
|
2023-03-02 09:55:33 +11:00
|
|
|
{
|
2025-01-13 22:03:47 +11:00
|
|
|
Config::set('update_available',Cache::get('upstream_version'));
|
2023-03-03 16:07:11 +11:00
|
|
|
|
2023-03-02 09:55:33 +11:00
|
|
|
return $next($request);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle tasks after the response has been sent to the browser.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2025-01-13 22:03:47 +11:00
|
|
|
public function terminate(): void
|
2023-03-02 09:55:33 +11:00
|
|
|
{
|
2023-03-03 16:07:11 +11:00
|
|
|
Cache::remember('upstream_version',self::UPDATE_TIME,function() {
|
2023-03-02 09:55:33 +11:00
|
|
|
// CURL call to URL to see if there is a new version
|
2023-03-03 16:07:11 +11:00
|
|
|
Log::debug(sprintf('CU_:Checking for updates for [%s]',config('app.version')));
|
|
|
|
|
|
|
|
$client = new Client;
|
|
|
|
|
2024-01-14 13:02:16 +11:00
|
|
|
try {
|
|
|
|
$response = $client->request('POST',sprintf('%s/%s',self::UPDATE_SERVER,strtolower(config('app.version'))));
|
2023-03-03 16:07:11 +11:00
|
|
|
|
2024-01-14 13:02:16 +11:00
|
|
|
if ($response->getStatusCode() === 200) {
|
|
|
|
$result = json_decode($response->getBody());
|
2023-03-03 16:07:11 +11:00
|
|
|
|
2024-01-14 13:02:16 +11:00
|
|
|
Log::debug(sprintf('CU_:- Update server returned...'),['update'=>$result]);
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
Log::debug(sprintf('CU_:- Exception connecting to update server'),['e'=>get_class($e)]);
|
2023-03-03 16:07:11 +11:00
|
|
|
}
|
2023-03-02 09:55:33 +11:00
|
|
|
|
2023-03-03 16:07:11 +11:00
|
|
|
return NULL;
|
2023-03-02 09:55:33 +11:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|