UserDutyCheckController.php 8.2 KB

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