| Conditions | 1 |
| Paths | 1 |
| Total Lines | 19 |
| Code Lines | 13 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 0 |
| CRAP Score | 2 |
| Changes | 0 | ||
| 1 | <?php |
||
| 30 | public function handle(): void |
||
| 31 | { |
||
| 32 | DB::transaction(function () { |
||
| 33 | $wallet = config('wallet.wallet.table'); |
||
| 34 | $trans = config('wallet.transaction.table'); |
||
| 35 | |||
| 36 | $availableBalance = DB::table($trans) |
||
| 37 | ->select('wallet_id', DB::raw('sum(amount) balance')) |
||
| 38 | ->where('confirmed', true) |
||
| 39 | ->groupBy('wallet_id'); |
||
| 40 | |||
| 41 | $joinClause = function (JoinClause $join) use ($wallet) { |
||
| 42 | $join->on("$wallet.id", '=', 'b.wallet_id'); |
||
| 43 | }; |
||
| 44 | |||
| 45 | DB::table($wallet)->update(['balance' => 0]); |
||
| 46 | DB::table($wallet) |
||
| 47 | ->joinSub($availableBalance, 'b', $joinClause, null, null, 'left') |
||
| 48 | ->update(['balance' => DB::raw('b.balance')]); |
||
| 49 | }); |
||
| 53 |