Files
UNIT3D-Community-Edition/app/Http/Controllers/User/RsskeyController.php
2023-11-16 09:53:56 +00:00

71 lines
2.5 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\Models\PrivateMessage;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class RsskeyController extends Controller
{
/**
* Update user rsskey.
*/
protected function update(Request $request, User $user): \Illuminate\Http\RedirectResponse
{
abort_unless($request->user()->is($user) || $request->user()->group->is_modo, 403);
$changedByStaff = $request->user()->isNot($user);
abort_if($changedByStaff && !$request->user()->group->is_owner && $request->user()->group->level <= $user->group->level, 403);
DB::transaction(function () use ($user, $changedByStaff): void {
$user->rsskeys()->latest()->first()?->update(['deleted_at' => now()]);
$user->update([
'rsskey' => md5(random_bytes(60).$user->password),
]);
$user->rsskeys()->create(['content' => $user->rsskey]);
if ($changedByStaff) {
PrivateMessage::create([
'sender_id' => 1,
'receiver_id' => $user->id,
'subject' => 'ATTENTION - Your RSS key has been reset',
'message' => "Your RSS key has been reset by staff. You will need to update your RSS key in your torrent client to continue receiving new torrents.\n\nFor more information, please create a helpdesk ticket.\n\n[color=red][b]THIS IS AN AUTOMATED SYSTEM MESSAGE, PLEASE DO NOT REPLY![/b][/color]",
]);
}
});
return to_route('users.rsskeys.index', ['user' => $user])
->withSuccess('Your RSS key was changed successfully.');
}
/**
* Edit user rsskey.
*/
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.rsskey.index', [
'user' => $user,
'rsskeys' => $user->rsskeys()->latest()->get(),
]);
}
}