File manager - Edit - /home/autoph/public_html/projects/test_api/app/Http/Controllers/API/v1/UserController.php
Back
<?php namespace App\Http\Controllers\API\v1; use App\Http\Controllers\Controller; use Illuminate\Http\Request; use Illuminate\Http\Response; use Illuminate\Support\Facades\Validator; use App\Models\User; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Hash; use DB; class UserController extends Controller { public function index(Request $request) { $keyword = $request->input('keyword', ''); $perPage = $request->input('per_page'); $sortBy = $request->input('sortBy', ''); $sortType = $request->input('sortType', ''); $data = User::where(function ($query) use ($keyword) { $query->where('first_name', 'like', '%' . $keyword . '%') ->orWhere('last_name', 'like', '%' . $keyword . '%') ->orWhere('name', 'like', '%' . $keyword . '%') ->orWhere('username', 'like', '%' . $keyword . '%') ->orWhere('email', 'like', '%' . $keyword . '%'); }); if (!empty($sortBy) && !empty($sortType)) { $data = $data->orderBy($sortBy, $sortType); } $data = $data->paginate($perPage); return response()->json($data); } public function login(Request $request) { $request->validate([ 'username' => 'required', 'password' => 'required', ]); $username = $request->username; $credentials = $request->only('username', 'password'); $token = Auth::attempt($credentials, ['exp' => \Carbon\Carbon::now()->addDays(1)->timestamp]); if (!$token) { return response()->json([ 'message' => 'Unauthorized', ], 401); } $user = Auth::user(); return response()->json([ 'user' => $user, 'token' => $token, ],200); } public function store(Request $request) { // Validate the incoming request data $validator = Validator::make($request->all(), [ 'code' => 'required|min:2|unique:companies,code' ]); if ($validator->fails()) { return response()->json(['errors' => $validator->errors()], Response::HTTP_UNPROCESSABLE_ENTITY); } DB::connection()->beginTransaction(); try { $data = User::create($request->all()); DB::connection()->commit(); return response()->json([ 'message' => 'Record Successfully added!', 'status' => 'success', ]); } catch (Throwable $e) { DB::connection()->rollback(); return response()->json([ 'status' => false, 'message' => 'Unable to process request. Please try again.', 'data' => $e->getMessage() ]); } } public function update(Request $request, string $code) { $data = User::where('code', $code)->first(); if (!$data) { return response()->json(['messages' => 'No data found.'], 404); } DB::connection()->beginTransaction(); try { $data->fill($request->all()); $data->save(); $data->touch(); DB::connection()->commit(); return response()->json([ 'message' => 'Record Successfully updated!', 'status' => 'success', 'data' => $data, ]); } catch (Throwable $e) { DB::connection()->rollback(); return response()->json([ 'status' => false, 'message' => 'Unable to process request. Please try again.', 'data' => $e->getMessage() ]); } } }
| ver. 1.4 |
.
| PHP 8.1.32 | Generation time: 0.08 |
proxy
|
phpinfo
|
Settings