Files
UNIT3D-Community-Edition/app/Http/Controllers/User/TipController.php
Roardom b6b4313bdc update: various database performance improvements
Use eager loading where necessary and add a few indexes. The existing index on private_messages for sender_id and read was probably a typo and intended for receiver_id. The first 3 tables indexes are added to are used for queries ran on every page load: namely the new pm, new notification and warnings indicator in the navbar. Additionally, another index on genre_movie proved useful for finding all the genres when given a movie id. Perhaps, another index for finding all movies within a genre would be good as well, but will leave that for a future optimization if deemed necessary.
2023-07-17 00:21:08 +00:00

94 lines
3.3 KiB
PHP

<?php
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author Roardom <roardom@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Http\Controllers\User;
use App\Http\Controllers\Controller;
use App\Http\Requests\StoreTipRequest;
use App\Models\BonTransactions;
use App\Models\Post;
use App\Models\Scopes\ApprovedScope;
use App\Models\Torrent;
use App\Models\User;
use App\Notifications\NewPostTip;
use App\Notifications\NewUploadTip;
use Illuminate\Http\Request;
/**
* @see \Tests\Feature\Http\Controllers\BonusControllerTest
*/
class TipController extends Controller
{
/**
* Show previous tip history.
*/
public function index(Request $request, User $user): \Illuminate\Contracts\View\Factory|\Illuminate\View\View
{
abort_unless($request->user()->is($user) || $request->user()->group->is_modo, 403);
return view('user.tip.index', [
'user' => $user,
'tips' => BonTransactions::with(['senderObj.group', 'receiverObj.group', 'torrent'])
->where(fn ($query) => $query->where('sender', '=', $user->id)->orwhere('receiver', '=', $user->id))
->where('name', '=', 'tip')
->latest('date_actioned')
->paginate(25),
'bon' => $user->getSeedbonus(),
'sentTips' => $user->sentTips()->sum('cost'),
'receivedTips' => $user->receivedTips()->sum('cost'),
]);
}
/**
* Tip Points To A User.
*
* @param User $user The tipping user.
*/
public function store(StoreTipRequest $request, User $user): \Illuminate\Http\RedirectResponse
{
abort_unless($request->user()->is($user), 403);
$request = $request->safe()->collect();
$tipable = match (true) {
$request->has('torrent') => Torrent::withoutGlobalScope(ApprovedScope::class)->findOrFail($request->get('torrent')),
$request->has('post') => Post::findOrFail($request->get('post')),
};
$recipient = $tipable->user;
$tipAmount = $request->get('tip');
$recipient->increment('seedbonus', $tipAmount);
$user->decrement('seedbonus', $tipAmount);
BonTransactions::create([
'itemID' => 0,
'name' => 'tip',
'cost' => $tipAmount,
'sender' => $user->id,
'receiver' => $recipient->id,
'comment' => 'tip',
'post_id' => $request->has('post') ? $tipable->id : null,
'torrent_id' => $request->has('torrent') ? $tipable->id : null,
]);
if ($request->has('torrent')) {
if ($recipient->acceptsNotification($user, $recipient, 'torrent', 'show_torrent_tip')) {
$recipient->notify(new NewUploadTip('torrent', $user->username, $tipAmount, $tipable));
}
} elseif ($request->has('post')) {
$recipient->notify(new NewPostTip('forum', $user->username, $tipAmount, $tipable));
}
return redirect()->back()->withSuccess(trans('bon.success-tip'));
}
}