From 770527c89dbefb0ebd8c78c948574b907db696f3 Mon Sep 17 00:00:00 2001 From: dasaint001 Date: Thu, 17 Nov 2022 06:35:56 +0100 Subject: [PATCH 1/3] feat: added get verified user by id in issue #18 --- backend/app/Http/Controllers/Controller.php | 54 +++++++++++++++++++ .../Http/Controllers/User/UserController.php | 27 ++++++++++ backend/app/Services/UserService.php | 19 +++++++ backend/routes/api.php | 5 ++ 4 files changed, 105 insertions(+) create mode 100644 backend/app/Http/Controllers/User/UserController.php create mode 100644 backend/app/Services/UserService.php diff --git a/backend/app/Http/Controllers/Controller.php b/backend/app/Http/Controllers/Controller.php index a0a2a8a3..48425237 100644 --- a/backend/app/Http/Controllers/Controller.php +++ b/backend/app/Http/Controllers/Controller.php @@ -10,4 +10,58 @@ class Controller extends BaseController { use AuthorizesRequests, DispatchesJobs, ValidatesRequests; + + /** + * @param $message + * @return Response + */ + protected function respondWithMissingField($message) + { + return response()->json([ + 'status' => 400, + 'message' => $message, + ], 400); + } + + /** + * @param $message + * @return Response + */ + private function respondWithValidationError($message) + { + return response()->json([ + 'status' => false, + 'message' => $message, + ], 400); + } + + /** + * @param $validator + * @return Response + */ + protected function respondWithErrorMessage($validator) + { + $required = $messages = []; + $validatorMessages = $validator->errors()->toArray(); + foreach($validatorMessages as $field => $message) { + if (strpos($message[0], 'required')) { + $required[] = $field; + } + + foreach ($message as $error) { + $messages[] = $error; + } + } + + if (count($required) > 0) { + $fields = implode(', ', $required); + $message = "Missing required fields $fields"; + + return $this->respondWithMissingField($message); + } + + + return $this->respondWithValidationError(implode(', ', $messages)); + } + } diff --git a/backend/app/Http/Controllers/User/UserController.php b/backend/app/Http/Controllers/User/UserController.php new file mode 100644 index 00000000..eee9c603 --- /dev/null +++ b/backend/app/Http/Controllers/User/UserController.php @@ -0,0 +1,27 @@ +json([ + 'status' => false, + 'message' => 'User does not exist or is not a verified user' + ], 404); + } + + return response()->json([ + 'status' => true, + 'user' => $verified_user + ], 200); + } +} \ No newline at end of file diff --git a/backend/app/Services/UserService.php b/backend/app/Services/UserService.php new file mode 100644 index 00000000..2943f60c --- /dev/null +++ b/backend/app/Services/UserService.php @@ -0,0 +1,19 @@ +where('isVerified', true)->first(); + + return $user; + } +} \ No newline at end of file diff --git a/backend/routes/api.php b/backend/routes/api.php index eb6fa48c..acf3f9b6 100644 --- a/backend/routes/api.php +++ b/backend/routes/api.php @@ -2,6 +2,7 @@ use Illuminate\Http\Request; use Illuminate\Support\Facades\Route; +use App\Http\Controllers\User\UserController; /* |-------------------------------------------------------------------------- @@ -17,3 +18,7 @@ Route::middleware('auth:sanctum')->get('/user', function (Request $request) { return $request->user(); }); + +Route::group(['prefix' => 'users'], function() { + Route::get('verified/{userId}', [UserController::class, 'getVerifiedUserById']); +}); \ No newline at end of file From 1b0ba5d340b52476336d5a8802ad3fa76a5e0e8c Mon Sep 17 00:00:00 2001 From: dasaint001 Date: Thu, 17 Nov 2022 06:57:27 +0100 Subject: [PATCH 2/3] fix: made fixes to the routes error --- backend/routes/api.php | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/backend/routes/api.php b/backend/routes/api.php index 51f9720f..9cd588c3 100644 --- a/backend/routes/api.php +++ b/backend/routes/api.php @@ -18,7 +18,7 @@ | */ -Route::prefix("v1")->group(function(){ +Route::group( ['prefix' => 'v1'], function() { // middleware instance here Route::middleware('auth:sanctum')->get('/user', function (Request $request) { @@ -27,12 +27,11 @@ // other route functions here Route::get("/test", function(){ - // execute the function - return sendResponse(false, 200, "Test case pass", null); - - Route::group(['prefix' => 'users'], function() { - Route::get('verified/{userId}', [UserController::class, 'getVerifiedUserById']); - }); + return sendResponse(false, 200, "Test case pass", null); + }); + + Route::group(['prefix' => 'users'], function() { + Route::get('verified/{userId}', [UserController::class, 'getVerifiedUserById']); }); }); \ No newline at end of file From 43596e2a1260be4d9f29ecae3fb37fb6b594b819 Mon Sep 17 00:00:00 2001 From: dasaint001 Date: Thu, 17 Nov 2022 06:59:54 +0100 Subject: [PATCH 3/3] fix: made fixes to the routes errors --- backend/routes/api.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/backend/routes/api.php b/backend/routes/api.php index 9cd588c3..f38f4f49 100644 --- a/backend/routes/api.php +++ b/backend/routes/api.php @@ -18,7 +18,7 @@ | */ -Route::group( ['prefix' => 'v1'], function() { +Route::prefix("v1")->group(function(){ // middleware instance here Route::middleware('auth:sanctum')->get('/user', function (Request $request) { @@ -31,7 +31,7 @@ return sendResponse(false, 200, "Test case pass", null); }); - Route::group(['prefix' => 'users'], function() { + Route::prefix("users")->group(function(){ Route::get('verified/{userId}', [UserController::class, 'getVerifiedUserById']); }); }); \ No newline at end of file