UserController.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\User;
  4. use Validator;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use App\Http\Controllers\Controller;
  8. use Illuminate\Support\Facades\Auth;
  9. class UserController extends Controller
  10. {
  11. /**
  12. * log a user in
  13. * @return [type] [description]
  14. */
  15. public function login(Request $request)
  16. {
  17. $validator = Validator::make($request->all(), [
  18. 'email' => 'required|exists:users,email',
  19. 'password' => 'required',
  20. ]);
  21. if ($validator->fails()) {
  22. return response()->json(['error' => $validator->errors()], 400);
  23. }
  24. $credentials = [
  25. 'email' => request('email'),
  26. 'password' => request('password')
  27. ];
  28. if (Auth::attempt($credentials)) {
  29. $success['token'] = Auth::user()->createToken('MyApp')->accessToken;
  30. $success['name'] = Auth::user()->name;
  31. return response()->json(['success' => $success], 200);
  32. }
  33. return response()->json(['error' => 'Unauthorised'], 401);
  34. }
  35. /**
  36. * log out current user
  37. * @param Request $request
  38. * @return json
  39. */
  40. public function logout()
  41. {
  42. $accessToken = Auth::user()->token();
  43. $accessToken->revoke();
  44. return response()->json(['success' => 'signed out']);
  45. }
  46. /**
  47. * check if a user exists
  48. * @param Request $request [description]
  49. * @return json
  50. */
  51. public function checkUser()
  52. {
  53. $count = DB::table('users')->count();
  54. return response()->json(['userCount' => $count], 200);
  55. }
  56. /**
  57. * register new user
  58. * @param Request $request [description]
  59. * @return json
  60. */
  61. public function register(Request $request)
  62. {
  63. // check if a user already exists
  64. $count = DB::table('users')->count();
  65. if( $count > 0 ) {
  66. return response()->json(['error' => __('already_one_user_registered')], 400);
  67. }
  68. $validator = Validator::make($request->all(), [
  69. 'name' => 'required',
  70. 'email' => 'required|email',
  71. 'password' => 'required|confirmed',
  72. ]);
  73. if ($validator->fails()) {
  74. return response()->json(['error' => $validator->errors()], 400);
  75. }
  76. $input = $request->all();
  77. $input['password'] = bcrypt($input['password']);
  78. $user = User::create($input);
  79. $success['token'] = $user->createToken('MyApp')->accessToken;
  80. $success['name'] = $user->name;
  81. return response()->json(['success' => $success]);
  82. }
  83. /**
  84. * get detailed information about a user
  85. * @return [type] [description]
  86. */
  87. public function getDetails()
  88. {
  89. return response()->json(Auth::user(), 200);
  90. }
  91. }