mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-28 14:10:51 -08:00
2adc4ffa96
https://github.com/snipe/snipe-it/pull/14702/files introduced a bug where instead of doing a quick `select count(*)` of assets, it did a `select *` of assets, moving the count from the database to the PHP process. This caused OOM issues in memory-constrained environments with lots of assets, and also presented a speed issue even when memory limited were increased. Additionally, given this populates the sidebar, this was likely an issue on every page load that included the sidebar. The fix is simply removing the `all()->`, ending up with Asset::count(), which yields the desired `select count(*)` DB query.
123 lines
3.7 KiB
PHP
123 lines
3.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
use App\Models\Asset;
|
|
use Auth;
|
|
use Closure;
|
|
use App\Models\Setting;
|
|
|
|
class AssetCountForSidebar
|
|
{
|
|
/**
|
|
* Handle an incoming request.
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param \Closure $next
|
|
* @return mixed
|
|
*/
|
|
public function handle($request, Closure $next)
|
|
{
|
|
/**
|
|
* This needs to be set for the /setup process, since the tables might not exist yet
|
|
*/
|
|
$total_assets = 0;
|
|
$total_due_for_checkin = 0;
|
|
$total_overdue_for_checkin = 0;
|
|
$total_due_for_audit = 0;
|
|
$total_overdue_for_audit = 0;
|
|
|
|
try {
|
|
$settings = Setting::getSettings();
|
|
view()->share('settings', $settings);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_assets = Asset::count();
|
|
if ($settings->show_archived_in_list != '1') {
|
|
$total_assets -= Asset::Archived()->count();
|
|
}
|
|
view()->share('total_assets', $total_assets);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_rtd_sidebar = Asset::RTD()->count();
|
|
view()->share('total_rtd_sidebar', $total_rtd_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_deployed_sidebar = Asset::Deployed()->count();
|
|
view()->share('total_deployed_sidebar', $total_deployed_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_archived_sidebar = Asset::Archived()->count();
|
|
view()->share('total_archived_sidebar', $total_archived_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_pending_sidebar = Asset::Pending()->count();
|
|
view()->share('total_pending_sidebar', $total_pending_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_undeployable_sidebar = Asset::Undeployable()->count();
|
|
view()->share('total_undeployable_sidebar', $total_undeployable_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_byod_sidebar = Asset::where('byod', '=', '1')->count();
|
|
view()->share('total_byod_sidebar', $total_byod_sidebar);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_due_for_audit = Asset::DueForAudit($settings)->count();
|
|
view()->share('total_due_for_audit', $total_due_for_audit);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_overdue_for_audit = Asset::OverdueForAudit()->count();
|
|
view()->share('total_overdue_for_audit', $total_overdue_for_audit);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_due_for_checkin = Asset::DueForCheckin($settings)->count();
|
|
view()->share('total_due_for_checkin', $total_due_for_checkin);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
try {
|
|
$total_overdue_for_checkin = Asset::OverdueForCheckin()->count();
|
|
view()->share('total_overdue_for_checkin', $total_overdue_for_checkin);
|
|
} catch (\Exception $e) {
|
|
\Log::debug($e);
|
|
}
|
|
|
|
view()->share('total_due_and_overdue_for_checkin', ($total_due_for_checkin + $total_overdue_for_checkin));
|
|
view()->share('total_due_and_overdue_for_audit', ($total_due_for_audit + $total_overdue_for_audit));
|
|
|
|
return $next($request);
|
|
}
|
|
}
|