feat: Make app update job unique

This commit is contained in:
Attila Kerekes 2022-11-22 17:22:36 +01:00 committed by Attila Jozsef Kerekes
parent 756ab353f3
commit 8957a2f49f
No known key found for this signature in database
GPG key ID: E1121565A016ADFD
3 changed files with 22 additions and 2 deletions

View file

@ -9,6 +9,7 @@ use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Log;
class UpdateApps implements ShouldQueue, ShouldBeUnique
@ -41,5 +42,17 @@ class UpdateApps implements ShouldQueue, ShouldBeUnique
Application::getApp($app['appid']);
sleep(1);
}
Log::debug('Update of all apps finished!');
Cache::lock('updateApps')->forceRelease();
}
/**
* @return void
*/
public function failed($exception)
{
Cache::lock('updateApps')->forceRelease();
}
}

View file

@ -8,6 +8,7 @@ use App\Jobs\UpdateApps;
use App\Setting;
use App\User;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\ServiceProvider;
@ -170,6 +171,12 @@ class AppServiceProvider extends ServiceProvider
*/
private function updateApps()
{
UpdateApps::dispatchAfterResponse();
// This lock ensures that the job is not invoked multiple times.
// In 5 minutes all app updates should be finished.
$lock = Cache::lock('updateApps', 5*60);
if ($lock->get()) {
UpdateApps::dispatchAfterResponse();
}
}
}

File diff suppressed because one or more lines are too long