Dashboard sipadu mbip
Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

LoginController.php 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace App\Http\Controllers\api;
  3. use Illuminate\Http\Request;
  4. use App\Http\Requests\RegisterRequest;
  5. use App\Http\Controllers\Api\BaseController;
  6. use Illuminate\Support\Facades\Auth;
  7. use Hash;
  8. use Carbon\Carbon;
  9. use Crypt;
  10. use File;
  11. use Mail;
  12. use App\Model\Staff;
  13. use App\Model\StaffDetail;
  14. use App\Model\Module\Department;
  15. use App\Model\User;
  16. use App\Model\UserDetail;
  17. class LoginController extends BaseController
  18. {
  19. /**
  20. * Create a login list controller.
  21. *
  22. * @return json
  23. */
  24. public function requestStaffLogin(Request $request) {
  25. $user = ''; $data = array();
  26. $rememberMe = false;
  27. $user = Staff::with(['StaffDetail' => function($q){
  28. $q->select('_id','full_name','identity','mobile','address','gred','no_badan','roles_access','profile_img');
  29. }])->where('no_badan',$request->no_badan)->where(function($q){
  30. $q->where('roles_access','PenguatKuasa')->orWhere('roles_access','PPenguatKuasa');
  31. })->first();
  32. if (!empty($user)) {
  33. if(Hash::check($request->password, $user->password)){
  34. // Check authorized
  35. do {
  36. $user->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  37. $user->last_login_ip = $request->getClientIp();
  38. $user->api_token = '';
  39. $user->authorized = false;
  40. $user->save();
  41. }while($user->authorized);
  42. $token_id = '';
  43. do {
  44. $token_id = str_random(32);
  45. } while (Staff::where("token_id", "=", $token_id)->first() instanceof Staff);
  46. $user->api_token = $token_id;
  47. $user->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  48. $user->last_login_ip = $request->getClientIp();
  49. $user->authorized = true;
  50. $user->token_firebase = '';
  51. $user->save();
  52. $staff = StaffDetail::with('Department')->where('_id', $user->_id)->first();
  53. if(!empty($staff->Department)){
  54. foreach ($staff->Department as $key => $d) {
  55. $tempJ[] = $d->_id;
  56. }
  57. $jabatan = implode( ", ", $tempJ );
  58. }
  59. array_push($data, array(
  60. 'User' => $user->StaffDetail,
  61. 'token' => $user->api_token,
  62. 'jawatan' => $user->StaffDetail->gred,
  63. 'token_firebase' => $user->token_firebase,
  64. 'jbkod' => $jabatan
  65. ));
  66. return $this->sendResponse($data, 'Berjaya log masuk');
  67. }else {
  68. return $this->sendError('Gagal', 'Emel atau kata-laluan tidak tepat');
  69. }
  70. }else {
  71. return $this->sendError('Gagal', 'Rekod tidak dijumpai');
  72. }
  73. }
  74. public function requestStaffLogout(Request $request){
  75. $loginUser = Staff::where('api_token', $request->api_token)->first();
  76. if(!empty($loginUser)){
  77. $loginUser->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  78. $loginUser->last_login_ip = $request->getClientIp();
  79. $loginUser->api_token = '';
  80. $loginUser->authorized = false;
  81. $loginUser->save();
  82. return $this->sendResponse('Berjaya', 'Berjaya log keluar');
  83. }else {
  84. return $this->sendError('Gagal', 'Maaf, penguatkuasa tidak dapat log keluar');
  85. }
  86. }
  87. // public function resetPassword(Request $request)
  88. // {
  89. // $data = array();
  90. // $staff = Staff::where('api_token', $request->api_token)->first();
  91. // if(!empty($staff))
  92. // {
  93. // $ic_num = StaffDetail::with('Staff')->where('identity', $request->ic_number)->first();
  94. // $id = $ic_num->_id;
  95. // if(!empty($id))
  96. // {
  97. // $staffID = Staff::where('_id', $id)->first();
  98. // $staffID->password = $request->new_password;
  99. // }
  100. // else
  101. // {
  102. // return $this->sendError('Gagal', 'Identiti tidak dijumpai');
  103. // }
  104. // }
  105. // else
  106. // {
  107. // return $this->sendError('Gagal', 'penguatkuasa tidak wujud');
  108. // }
  109. // }
  110. }