[admin] add setting backup

This commit is contained in:
xiaomlove
2021-05-14 20:41:43 +08:00
parent 6c85176e2f
commit 47f64f2c5c
23 changed files with 787 additions and 39 deletions

View 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)
{
}
}

View File

@@ -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);
}
}

View File

@@ -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')),
];
}
}

View File

@@ -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,