Dashboard sipadu mbip
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

LoginController.php 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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. use App\Model\Module\Compound;
  18. use App\Jobs\StoreCompound;
  19. use App\Jobs\StoreNotice;
  20. class LoginController extends BaseController
  21. {
  22. /**
  23. * Create a login list controller.
  24. *
  25. * @return json
  26. */
  27. public function requestStaffLogin(Request $request) {
  28. $user = ''; $data = array();
  29. $rememberMe = false;
  30. $user = Staff::with(['StaffDetail' => function($q){
  31. $q->select('_id','full_name','identity','mobile','address','gred','no_badan','roles_access','profile_img');
  32. }])->where('no_badan',$request->no_badan)->where(function($q){
  33. $q->where('roles_access','PenguatKuasa')->orWhere('roles_access','PPenguatKuasa');
  34. })->first();
  35. if (!empty($user)) {
  36. if(Hash::check($request->password, $user->password)){
  37. // Check authorized
  38. do {
  39. $user->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  40. $user->last_login_ip = $request->getClientIp();
  41. $user->api_token = '';
  42. $user->authorized = false;
  43. $user->save();
  44. }while($user->authorized);
  45. $token_id = '';
  46. do {
  47. $token_id = str_random(32);
  48. } while (Staff::where("token_id", "=", $token_id)->first() instanceof Staff);
  49. $user->api_token = $token_id;
  50. $user->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  51. $user->last_login_ip = $request->getClientIp();
  52. $user->authorized = true;
  53. $user->token_firebase = '';
  54. $user->save();
  55. $staff = StaffDetail::with('Department')->where('_id', $user->_id)->first();
  56. if(!empty($staff->Department)){
  57. foreach ($staff->Department as $key => $d) {
  58. $tempJ[] = $d->_id;
  59. }
  60. $jabatan = implode( ", ", $tempJ );
  61. }
  62. array_push($data, array(
  63. 'User' => $user->StaffDetail,
  64. 'token' => $user->api_token,
  65. 'jawatan' => $user->StaffDetail->gred,
  66. 'token_firebase' => $user->token_firebase,
  67. 'jbkod' => $jabatan
  68. ));
  69. return $this->sendResponse($data, 'Berjaya log masuk');
  70. }else {
  71. return $this->sendError('Gagal', 'Emel atau kata-laluan tidak tepat');
  72. }
  73. }else {
  74. return $this->sendError('Gagal', 'Rekod tidak dijumpai');
  75. }
  76. }
  77. public function requestStaffLogout(Request $request){
  78. $loginUser = Staff::where('api_token', $request->api_token)->first();
  79. if(!empty($loginUser)){
  80. $loginUser->last_login_at = Carbon::now(new \DateTimeZone('Asia/Kuala_Lumpur'))->toDateTimeString();
  81. $loginUser->last_login_ip = $request->getClientIp();
  82. $loginUser->api_token = '';
  83. $loginUser->authorized = false;
  84. $loginUser->save();
  85. return $this->sendResponse('Berjaya', 'Berjaya log keluar');
  86. }else {
  87. return $this->sendError('Gagal', 'Maaf, penguatkuasa tidak dapat log keluar');
  88. }
  89. }
  90. // public function resetPassword(Request $request)
  91. // {
  92. // $data = array();
  93. // $staff = Staff::where('api_token', $request->api_token)->first();
  94. // if(!empty($staff))
  95. // {
  96. // $ic_num = StaffDetail::with('Staff')->where('identity', $request->ic_number)->first();
  97. // $id = $ic_num->_id;
  98. // if(!empty($id))
  99. // {
  100. // $staffID = Staff::where('_id', $id)->first();
  101. // $staffID->password = $request->new_password;
  102. // }
  103. // else
  104. // {
  105. // return $this->sendError('Gagal', 'Identiti tidak dijumpai');
  106. // }
  107. // }
  108. // else
  109. // {
  110. // return $this->sendError('Gagal', 'penguatkuasa tidak wujud');
  111. // }
  112. // }
  113. public function testing(Request $request)
  114. {
  115. $test = '02399'; //filter_var('000099', FILTER_SANITIZE_NUMBER_INT);
  116. (int)$test += 1;
  117. dd($test);
  118. }
  119. }