mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-14 04:20:49 +08:00
[admin] add setting backup
This commit is contained in:
77
app/Http/Controllers/SettingController.php
Normal file
77
app/Http/Controllers/SettingController.php
Normal file
@@ -0,0 +1,77 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Repositories\SettingRepository;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
|
||||
class SettingController extends Controller
|
||||
{
|
||||
private $repository;
|
||||
|
||||
public function __construct(SettingRepository $repository)
|
||||
{
|
||||
$this->repository = $repository;
|
||||
}
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @param Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
$result = $this->repository->getList($request->all());
|
||||
return $this->success($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$result = $this->repository->store($request->all());
|
||||
return $this->success($result, 'Save setting success!');
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return array
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return array
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return array
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Http\Resources\ExamResource;
|
||||
use App\Http\Resources\InviteResource;
|
||||
use App\Http\Resources\UserResource;
|
||||
use App\Repositories\ExamRepository;
|
||||
use App\Repositories\UserRepository;
|
||||
@@ -90,14 +91,13 @@ class UserController extends Controller
|
||||
public function resetPassword(Request $request)
|
||||
{
|
||||
$rules = [
|
||||
'username' => 'required|string|exists:users',
|
||||
'uid' => 'required',
|
||||
'password' => 'required|string|min:6|max:40',
|
||||
'password_confirmation' => 'required|same:password',
|
||||
];
|
||||
$request->validate($rules);
|
||||
$result = $this->repository->resetPassword($request->repositoryname, $request->password, $request->password_confirmation);
|
||||
$resource = new UserResource($result);
|
||||
return $this->success($resource);
|
||||
$result = $this->repository->resetPassword($request->uid, $request->password, $request->password_confirmation);
|
||||
return $this->success($result, 'Reset password success!');
|
||||
}
|
||||
|
||||
public function classes()
|
||||
@@ -132,6 +132,35 @@ class UserController extends Controller
|
||||
'reason' => 'required',
|
||||
]);
|
||||
$result = $this->repository->disableUser(Auth::user(), $request->uid, $request->reason);
|
||||
return $this->success($result, 'Disable user success!');
|
||||
}
|
||||
|
||||
public function enable(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'uid' => 'required',
|
||||
]);
|
||||
$result = $this->repository->enableUser(Auth::user(), $request->uid);
|
||||
return $this->success($result, 'Enable user success!');
|
||||
}
|
||||
|
||||
public function inviteInfo(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'uid' => 'required',
|
||||
]);
|
||||
$result = $this->repository->getInviteInfo($request->uid);
|
||||
$resource = $result ? (new InviteResource($result)) : null;
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
public function modComment(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'uid' => 'required',
|
||||
]);
|
||||
$result = $this->repository->getModComment($request->uid);
|
||||
return $this->success($result);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -25,6 +25,8 @@ class InviteResource extends JsonResource
|
||||
'invitee_register_uid' => $this->invitee_register_uid,
|
||||
'invitee_register_email' => $this->invitee_register_email,
|
||||
'invitee_register_username' => $this->invitee_register_username,
|
||||
'inviter_user' => new UserResource($this->whenLoaded('inviter_user')),
|
||||
'invitee_user' => new UserResource($this->whenLoaded('invitee_user')),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -19,6 +19,7 @@ class UserResource extends JsonResource
|
||||
'email' => $this->email,
|
||||
'username' => $this->username,
|
||||
'status' => $this->status,
|
||||
'enabled' => $this->enabled,
|
||||
'added' => format_datetime($this->added),
|
||||
'class' => $this->class,
|
||||
'class_text' => $this->class_text,
|
||||
|
||||
Reference in New Issue
Block a user