first commit

This commit is contained in:
2024-05-21 13:41:01 +08:00
commit 95a1c62d67
102 changed files with 13303 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ConfirmsPasswords;
class ConfirmPasswordController extends Controller
{
/*
|--------------------------------------------------------------------------
| Confirm Password Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling password confirmations and
| uses a simple trait to include the behavior. You're free to explore
| this trait and override any functions that require customization.
|
*/
use ConfirmsPasswords;
/**
* Where to redirect users when the intended url fails.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth');
}
}

View File

@@ -0,0 +1,22 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\SendsPasswordResetEmails;
class ForgotPasswordController extends Controller
{
/*
|--------------------------------------------------------------------------
| Password Reset Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling password reset emails and
| includes a trait which assists in sending these notifications from
| your application to your users. Feel free to explore this trait.
|
*/
use SendsPasswordResetEmails;
}

View File

@@ -0,0 +1,39 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
class LoginController extends Controller
{
/*
|--------------------------------------------------------------------------
| Login Controller
|--------------------------------------------------------------------------
|
| This controller handles authenticating users for the application and
| redirecting them to your home screen. The controller uses a trait
| to conveniently provide its functionality to your applications.
|
*/
use AuthenticatesUsers;
/**
* Where to redirect users after login.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest')->except('logout');
}
}

View File

@@ -0,0 +1,72 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Foundation\Auth\RegistersUsers;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
class RegisterController extends Controller
{
/*
|--------------------------------------------------------------------------
| Register Controller
|--------------------------------------------------------------------------
|
| This controller handles the registration of new users as well as their
| validation and creation. By default this controller uses a trait to
| provide this functionality without requiring any additional code.
|
*/
use RegistersUsers;
/**
* Where to redirect users after registration.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest');
}
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data)
{
return Validator::make($data, [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
'password' => ['required', 'string', 'min:8', 'confirmed'],
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return \App\Models\User
*/
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => Hash::make($data['password']),
]);
}
}

View File

@@ -0,0 +1,29 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ResetsPasswords;
class ResetPasswordController extends Controller
{
/*
|--------------------------------------------------------------------------
| Password Reset Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling password reset requests
| and uses a simple trait to include this behavior. You're free to
| explore this trait and override any methods you wish to tweak.
|
*/
use ResetsPasswords;
/**
* Where to redirect users after resetting their password.
*
* @var string
*/
protected $redirectTo = '/home';
}

View File

@@ -0,0 +1,41 @@
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\VerifiesEmails;
class VerificationController extends Controller
{
/*
|--------------------------------------------------------------------------
| Email Verification Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling email verification for any
| user that recently registered with the application. Emails may also
| be re-sent if the user didn't receive the original email message.
|
*/
use VerifiesEmails;
/**
* Where to redirect users after verification.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth');
$this->middleware('signed')->only('verify');
$this->middleware('throttle:6,1')->only('verify', 'resend');
}
}

View File

@@ -0,0 +1,10 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class AuthController extends Controller
{
//
}

View File

@@ -0,0 +1,12 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Validation\ValidatesRequests;
use Illuminate\Routing\Controller as BaseController;
class Controller extends BaseController
{
use AuthorizesRequests, ValidatesRequests;
}

View File

@@ -0,0 +1,26 @@
<?php
namespace App\Http\Controllers;
class HomeController extends Controller
{
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth');
}
/**
* Show the application dashboard.
*
* @return \Illuminate\Contracts\Support\Renderable
*/
public function index()
{
return view('home');
}
}

View File

@@ -0,0 +1,172 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\User;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Validator;
use App\Http\Requests\UserStoreRequest;
class UserController extends Controller
{
public function index()
{
$users = User::all();
return response()->json(
$users
,200);
}
public function createUser(Request $request)
{
try{
$validateUser = Validator::make($request->all(), [
"name"=> "required",
"email"=> "required|email|unique:users,email",
"password"=> "required"
]);
if( $validateUser->fails() ){
return response()->json([
'status' => false,
'message' => 'validation error',
'errors'=> $validateUser->errors()
], 401);
}
User::create([
'name' => $request->name,
'email'=> $request->email,
'password'=> Hash::make($request->password),
]);
return response()->json([
'status' => true,
'message' => 'User Created Successfully',
// 'token' => $user->createToken('API TOKEN')->plainTextToken
],
200);
} catch(\Throwable $th) {
Log::error('UserController - createUser(): '.$th->getMessage());
return response()->json([
'status' => false,
'message' => $th->getMessage(),
], 500);
}
}
public function loginUser(Request $request)
{
try{
$validateUser = Validator::make($request->all(), [
"email"=> "required",
"password"=> "required"
]);
if( $validateUser->fails() ){
return response()->json([
'status' => false,
'message' => 'validation error',
'errors'=> $validateUser->errors()
], 401);
}
if(!Auth::attempt($request->only(['email','password']))){
return response()->json([
'status' => false,
'message' => 'Email & Password does not match with our record.',
], 401);
}
return response()->json([
'status' => true,
'message' => 'User Logged in Successfully',
], 200);
}catch(\Throwable $th) {}
}
public function store(Request $request)
{
try{
//CREATE USER
User::create([
'name'=> $request->name,
'email'=> $request->email,
'password'=> Hash::make($request->password),
]);
//RETURN JSON
return response()->json([
'message'=> 'User successfully created.'
],200);
} catch(\Throwable $th){
Log::error('UserController - store(): '.$th->getMessage());
return response()->json([
'message' => $th->getMessage(),
], 500);
}
}
public function show($id)
{
//USER DETAIL
$users = User::find($id);
if(!$users){
return response()->json([
'message'=>'User Not Found.'
],404);
}
return response()->json(
$users
,200);
}
public function update(UserStoreRequest $request, $id)
{
try{
$users = User::find($id);
if(!$users){
return response()->json([
'message'=>'User Not Found.'
],404);
}
$users->name = $request->name;
$users->email = $request->email;
$users->password = Hash::make($request->password);
//Update User
$users->save();
//Return JSON
return response()->json([
'message'=>'User successfully Updated!'
],200);
} catch(\Exception $e){
return response()->json([
'message' => "Something went really wrong!"
],500);
}
}
public function destroy($id)
{
//USER DETAIL
$users = User::find($id);
if(!$users){
return response()->json([
"message"=> "User Not Found!"
],404);
}
//DELETE USER
$users->delete();
//RETURN JSON
return response()->json([
'message'=> "User successfully deleted."
],200);
}
}