client->id} {$uuid}"); MultiDB::setDb($this->company->db); $dupes = CompanyLedger::query() ->where('client_id', $this->client->id) ->where('balance', 0) ->where('hash', '<>', '') ->groupBy(['adjustment','hash']) ->havingRaw('COUNT(*) > 1') ->pluck('id'); // CompanyLedger::query()->whereIn('id', $dupes)->delete(); $dupes = CompanyLedger::query() ->where('client_id', $this->client->id) ->where('balance', 0) ->where('hash', '<>', '') ->groupBy(['adjustment','hash']) ->havingRaw('COUNT(*) > 1') ->pluck('id'); // CompanyLedger::query()->whereIn('id', $dupes)->delete(); CompanyLedger::query() ->where('balance', 0) ->where('client_id', $this->client->id) ->orderBy('id', 'ASC') ->get() ->each(function ($company_ledger) { $parent_ledger = CompanyLedger::query() ->where('id', '<', $company_ledger->id) ->where('client_id', $company_ledger->client_id) ->where('company_id', $company_ledger->company_id) ->where('balance', '!=', 0) ->orderBy('id', 'DESC') ->first(); // if ($company_ledger->balance == 0) { // $last_record = CompanyLedger::query() // ->where('client_id', $company_ledger->client_id) // ->where('company_id', $company_ledger->company_id) // ->where('balance', '!=', 0) // ->orderBy('id', 'DESC') // ->first(); // if (! $last_record) { // $last_record = CompanyLedger::query() // ->where('client_id', $company_ledger->client_id) // ->where('company_id', $company_ledger->company_id) // ->orderBy('id', 'DESC') // ->first(); // } // } // $company_ledger->balance = $last_record->balance + $company_ledger->adjustment; $company_ledger->balance = ($parent_ledger ? $parent_ledger->balance : 0) + $company_ledger->adjustment; $company_ledger->save(); }); nlog("finished job {$uuid}"); } public function middleware() { nlog("middle ware {$this->client->id}"); return [(new WithoutOverlapping($this->client->id))->dontRelease()]; } }