user-list

This commit is contained in:
xiaomlove
2021-04-17 19:01:33 +08:00
parent d734788363
commit 736d42cd5c
18 changed files with 699 additions and 803 deletions
+97
View File
@@ -0,0 +1,97 @@
<?php
namespace App\Http\Controllers;
use App\Http\Resources\UserResource;
use App\Repositories\UserRepository;
use Illuminate\Http\Request;
class UserController extends Controller
{
private $user;
public function __construct(UserRepository $user)
{
$this->user = $user;
}
/**
* Display a listing of the resource.
*
* @param Request $request
* @return array
*/
public function index(Request $request)
{
$result = $this->user->getList($request->all());
$resource = UserResource::collection($result);
return success('user list', $resource);
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function store(Request $request)
{
$rules = [
'username' => 'required|string',
'email' => 'required|email|unique:users',
'password' => 'required|string|min:6|max:40',
'password_confirmation' => 'required|string|same:password'
];
$request->validate($rules);
$result = $this->user->store($request->all());
$resource = new UserResource($result);
return success('user store', $resource);
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
//
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
//
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
//
}
public function resetPassword(Request $request)
{
$rules = [
'username' => 'required|string|exists:users',
'password' => 'required|string|min:6|max:40',
'password_confirmation' => 'required|same:password',
];
$request->validate($rules);
$result = $this->user->resetPassword($request->username, $request->password, $request->password_confirmation);
$resource = new UserResource($result);
return success('user reset password', $resource);
}
}
+31
View File
@@ -0,0 +1,31 @@
<?php
namespace App\Http\Resources;
use Illuminate\Http\Resources\Json\JsonResource;
class UserResource extends JsonResource
{
/**
* Transform the resource into an array.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function toArray($request)
{
return [
'id' => $this->id,
'email' => $this->email,
'username' => $this->username,
'status' => $this->status,
'added' => $this->added,
'class' => $this->class,
'avatar' => $this->avatar,
'uploaded' => $this->uploaded,
'downloaded' => $this->downloaded,
'seedtime' => $this->seedtime,
'leechtime' => $this->leechtime,
];
}
}
+10
View File
@@ -11,5 +11,15 @@ class NexusModel extends Model
public $timestamps = false;
/**
* 为数组 / JSON 序列化准备日期。
*
* @param \DateTimeInterface $date
* @return string
*/
protected function serializeDate(\DateTimeInterface $date)
{
return $date->format($this->dateFormat ?: 'Y-m-d H:i:s');
}
}
+33
View File
@@ -0,0 +1,33 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Support\Arr;
class Setting extends NexusModel
{
use HasFactory;
protected $fillable = ['name', 'value'];
public static function get($name = null)
{
static $settings;
if (is_null($settings)) {
$rows = self::query()->get(['name', 'value']);
foreach ($rows as $row) {
$value = $row->value;
$arr = json_decode($value, true);
if (is_array($arr)) {
$value = $arr;
}
Arr::set($settings, $row->name, $value);
}
}
if (is_null($name)) {
return $settings;
}
return Arr::get($settings, $name);
}
}
+18 -5
View File
@@ -11,16 +11,29 @@ class User extends Authenticatable
{
use HasFactory, Notifiable;
public $timestamps = false;
const STATUS_CONFIRMED = 'confirmed';
const STATUS_PENDING = 'pending';
/**
* 为数组 / JSON 序列化准备日期。
*
* @param \DateTimeInterface $date
* @return string
*/
protected function serializeDate(\DateTimeInterface $date)
{
return $date->format($this->dateFormat ?: 'Y-m-d H:i:s');
}
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name',
'email',
'password',
];
protected $fillable = ['username', 'email', 'password', 'secret', 'editsecret', 'added'];
/**
* The attributes that should be hidden for arrays.
+18
View File
@@ -0,0 +1,18 @@
<?php
namespace App\Repositories;
use Illuminate\Support\Str;
class BaseRepository
{
protected function getSortFieldAndType(array $params)
{
$field = $params['sort_field'] ?? 'id';
$type = 'desc';
if (!empty($params['sort_type']) && Str::startsWith($params['sort_type'], 'asc')) {
$type = 'asc';
}
return [$field, $type];
}
}
+56
View File
@@ -0,0 +1,56 @@
<?php
namespace App\Repositories;
use App\Models\Setting;
use App\Models\User;
class UserRepository extends BaseRepository
{
public function getList(array $params)
{
$query = User::query();
list($sortField, $sortType) = $this->getSortFieldAndType($params);
$query->orderBy($sortField, $sortType);
return $query->paginate();
}
public function store(array $params)
{
$password = $params['password'];
if ($password != $params['password_confirmation']) {
throw new \InvalidArgumentException("password confirmation != password");
}
$setting = Setting::get('main');
$secret = mksecret();
$passhash = md5($secret . $password . $secret);
$data = [
'username' => $params['username'],
'email' => $params['email'],
'secret' => $secret,
'editsecret' => '',
'passhash' => $passhash,
'stylesheet' => $setting['defstylesheet'],
'added' => now()->toDateTimeString(),
'status' => User::STATUS_CONFIRMED,
];
$user = User::query()->create($data);
return $user;
}
public function resetPassword($username, $password, $passwordConfirmation)
{
if ($password != $passwordConfirmation) {
throw new \InvalidArgumentException("password confirmation != password");
}
$user = User::query()->where('username', $username)->firstOrFail();
$secret = mksecret();
$passhash = md5($secret . $password . $secret);
$update = [
'secret' => $secret,
'passhash' => $passhash,
];
$user->update($update);
return $user;
}
}