UserDutyCheckController.php 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\User;
  4. use App\UserDetail;
  5. use App\UserDutyCheck;
  6. use App\UserLabor;
  7. use App\UserToken;
  8. use App\UserWorkGroup;
  9. use Carbon\Carbon;
  10. use Endroid\QrCode\QrCode;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Http\Response;
  13. use Illuminate\Support\Facades\Cache;
  14. use Illuminate\Support\Facades\Validator;
  15. use Ramsey\Uuid\Uuid;
  16. class UserDutyCheckController extends Controller
  17. {
  18. public function goGetQRCode(){
  19. $userWorkGroups=UserWorkGroup::get();
  20. return view("personnel/checking-in/getQRcode",compact('userWorkGroups'));
  21. }
  22. //获取二维码
  23. public function getQRCode(Request $request){
  24. $userWorkGroup_id=$request->input('userWorkGroup_id');
  25. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  26. if ($qrCode_refresh_everyday){
  27. $date=md5(date('Y-m-d'));
  28. $url=url("personnel/checking-in/userDutyCheck/clock?key=").$date;
  29. if ($userWorkGroup_id)$url=$url."&&userWorkGroupID=".$userWorkGroup_id;
  30. }else{
  31. $url=url("personnel/checking-in/userDutyCheck/clock");
  32. if ($userWorkGroup_id)$url=$url."?userWorkGroupID=".$userWorkGroup_id;
  33. }
  34. $qrCode=new QrCode($url);
  35. if ($userWorkGroup_id){
  36. if (file_exists("images/QRCodeIMG/".$userWorkGroup_id.'.png')){
  37. return "images/QRCodeIMG/".$userWorkGroup_id.'.png';
  38. }
  39. $qrCode->writeFile(storage_path('app/public/QRCodeIMG/'.$userWorkGroup_id.'.png'));
  40. return 'images/QRCodeIMG/'.$userWorkGroup_id.'.png';
  41. }
  42. return (new Response())->header('Content-Type',$qrCode->getContentType())->setContent($qrCode->writeString());
  43. }
  44. //校验二维码进入打卡页面
  45. public function clock(Request $request){
  46. $userWorkGroupID=$request->input('userWorkGroupID');
  47. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  48. if ($qrCode_refresh_everyday){
  49. $key=$request->input('key');
  50. if (!$key) return "二维码失效!";
  51. $date=md5(date('Y-m-d'));
  52. if ($key!=$date) return "二维码失效!";
  53. }
  54. $userLaborToken=$request->cookie('userLaborToken');
  55. if ($userLaborToken && Cache::has('tokenStr_'.$userLaborToken)) {
  56. $user_id=Cache::get('tokenStr_'.$userLaborToken);
  57. $userDetail=UserDetail::find($user_id);
  58. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("userWorkGroupID",$userWorkGroupID);
  59. if ($userWorkGroupID){
  60. $user=UserToken::getUser($userLaborToken);
  61. $user->userWorkGroups()->sync([$userWorkGroupID]);
  62. }
  63. $userDutyCheck=$this->dutyCheck($userDetail->user_id);
  64. if (!$userDutyCheck)return "<h1 style='color: red'>打卡异常,请联系相关人员!</h1>";
  65. return response()->view('personnel/checking-in/success',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at]);
  66. }
  67. return view("personnel/checking-in/clock",compact('userWorkGroupID'));
  68. }
  69. //提交打卡
  70. public function storeClock(Request $request){
  71. $mobile_phone=$request->input('mobile_phone');
  72. $userWorkGroupID=$request->input('userWorkGroupID');
  73. $this->validator($request)->validate();
  74. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  75. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("userWorkGroupID",$userWorkGroupID);
  76. $user=User::find($userDetail->user_id);
  77. if (Cache::has('tokenUser_'.$user->id))return "<h1 style='color: red'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  78. if ($userWorkGroupID)$user->userWorkGroups()->sync([$userWorkGroupID]);
  79. $userDutyCheck=$this->dutyCheck($userDetail->user_id);
  80. if (!$userDutyCheck)return "<h1 style='color: red'>打卡异常,请联系相关人员!</h1>";
  81. $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
  82. return response()->view('personnel/checking-in/success',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at])
  83. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  84. }
  85. //去往登记资料页面
  86. public function createUserDetail($mobile_phone){
  87. $userWorkGroupID=session("userWorkGroupID");
  88. return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'userWorkGroupID'=>$userWorkGroupID]);
  89. }
  90. //提交登记资料
  91. public function storeUserDetail(Request $request){
  92. $this->validator($request)->validate();
  93. $mobile_phone=$request->input('mobile_phone');
  94. $full_name=$request->input('full_name');
  95. $userWorkGroupID=$request->input('userWorkGroupID');
  96. $user=new User([
  97. 'name'=>$mobile_phone,
  98. 'password'=>Uuid::uuid1(),
  99. ]);
  100. $user->save();
  101. if ($userWorkGroupID)$user->userWorkGroups()->sync([$userWorkGroupID]);
  102. $userDetail=new UserDetail([
  103. 'user_id'=>$user->id,
  104. 'full_name'=>$full_name,
  105. 'gender'=>$request->input('gender'),
  106. 'mobile_phone'=>$mobile_phone,
  107. 'type'=>'临时工',
  108. ]);
  109. $userDetail->save();
  110. $userLabor=new UserLabor([
  111. 'user_id'=>$user->id,
  112. 'company'=>$request->input('company'),
  113. ]);
  114. $userLabor->save();
  115. $userDutyCheck=$this->dutyCheck($user->id);
  116. if (!$userDutyCheck)return "<h1 style='color: red'>打卡异常,请联系相关人员!</h1>";
  117. $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
  118. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request));
  119. return response()->view('personnel/checking-in/success',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at])
  120. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  121. }
  122. //根据用户提交打卡记录
  123. public function dutyCheck($user_id){
  124. $userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  125. $date=date('Y-m-d H:i:s');
  126. $userDutyCheck=new UserDutyCheck([
  127. 'user_id'=>$user_id,
  128. 'checked_at'=>$date,
  129. 'source'=>'正常',
  130. ]);
  131. if (!$userDutyCheckOld){
  132. $userDutyCheck->type="登入";
  133. $userDutyCheck->save();
  134. return $userDutyCheck;
  135. }
  136. $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
  137. $thisDate=Carbon::parse($date);
  138. $diffDate=$thisDate->diffInMinutes($lastDate);
  139. if ($userDutyCheckOld->type=="登入"){
  140. switch ($diffDate){
  141. case $diffDate<=20:
  142. $userDutyCheck->type="登入";
  143. break;
  144. case $diffDate>=1380:
  145. $userDutyCheck->type="登入";
  146. break;
  147. default:
  148. $userDutyCheck->type="登出";
  149. }
  150. }
  151. if ($userDutyCheckOld->type=="登出"){
  152. switch ($diffDate){
  153. case $diffDate<=20:
  154. $userDutyCheck->type="登出";
  155. break;
  156. default:
  157. $userDutyCheck->type="登入";
  158. }
  159. }
  160. $userDutyCheck->save();
  161. return $userDutyCheck;
  162. }
  163. public function validator(Request $request){
  164. $validator=Validator::make($request->input(),[
  165. 'full_name'=>['filled'],
  166. 'gender'=>['filled'],
  167. 'mobile_phone'=>['required','integer','digits:11'],
  168. ],[],[]);
  169. return $validator;
  170. }
  171. }