UserDutyCheckController.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Events\ClockinEvent;
  4. use App\Events\ClockoutEvent;
  5. use App\LaborCompany;
  6. use App\LaborReport;
  7. use App\User;
  8. use App\UserDetail;
  9. use App\UserDutyCheck;
  10. use App\UserLabor;
  11. use Carbon\Carbon;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Facades\Auth;
  14. use Illuminate\Support\Facades\Cache;
  15. use Illuminate\Support\Facades\Validator;
  16. use Ramsey\Uuid\Uuid;
  17. class UserDutyCheckController extends Controller
  18. {
  19. //校验二维码进入打卡页面
  20. public function clock(Request $request){
  21. $userWorkgroupID=$request->input('userWorkgroupID');
  22. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  23. $qrCode_refresh=config('hr.qrCode_refresh');
  24. if ($qrCode_refresh_everyday){
  25. $key=$request->input('key');
  26. if (!$key) return view('exception.404',['error'=>'二维码失效!']);
  27. $date=md5(date('Y-m-d'));
  28. if ($key!=$date) return view('exception.404',['error'=>'二维码失效!']);
  29. }
  30. if ($qrCode_refresh){
  31. $key=$request->input('key');
  32. if (!$key) return view('exception.404',['error'=>'二维码失效!']);
  33. $date=date('Y-m-d H:i:s');
  34. if ($key<$date) return view('exception.404',['error'=>'二维码失效!']);
  35. }
  36. $userLaborToken=$request->cookie('userLaborToken');
  37. if ($userLaborToken && Cache::has('dutyCheckTokenStr_'.$userLaborToken)) {
  38. $user_id=Cache::get('dutyCheckTokenStr_'.$userLaborToken);
  39. $userDetail=UserDetail::find($user_id);
  40. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  41. $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
  42. if ($userDutyCheck&&$userDutyCheck->type=='登入'){
  43. event(new ClockinEvent($userDutyCheck));
  44. }else if ($userDutyCheck&&$userDutyCheck->type=='登出'){
  45. event(new ClockoutEvent($userDutyCheck));
  46. }
  47. //正常情况
  48. $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',Carbon::now()->format('Y-m-d')."%")->where('user_id',$userDetail->user_id)->first();
  49. if ($laborReport&&$userDutyCheck->type=='登出'){
  50. LaborReport::updateLaborReportData($laborReport,$userDutyCheck);
  51. $this->log(__METHOD__,"更新临时工报表记录__".__FUNCTION__,json_encode($laborReport));
  52. }
  53. if ($userDutyCheck&&$userDutyCheck->error==true)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  54. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  55. $group_name=$userDutyCheck->userWorkgroup['name'];
  56. $laravelEchoPrefix = config('database.redis.options.prefix');
  57. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix]);
  58. }
  59. return view("personnel/checking-in/clock",compact('userWorkgroupID'));
  60. }
  61. //提交打卡
  62. public function storeClock(Request $request){
  63. $mobile_phone=$request->input('mobile_phone');
  64. $userWorkgroupID=$request->input('userWorkgroupID');
  65. $this->validator($request)->validate();
  66. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  67. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  68. if (Cache::has('dutyCheckTokenUser_'.$userDetail->user_id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  69. $userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  70. $date=date('Y-m-d H:i:s');
  71. $lastDate=Carbon::parse($userDutyCheckOld['checked_at']);
  72. $thisDate=Carbon::parse($date);
  73. $diffDate=$thisDate->diffInMinutes($lastDate);
  74. $dateNow=Carbon::now()->format('Y-m-d');
  75. //七天未登录从新选择劳务所
  76. if ($diffDate>7*1440){
  77. return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  78. }
  79. $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
  80. if ($userDutyCheck&&$userDutyCheck->type=='登入'){
  81. event(new ClockinEvent($userDutyCheck));
  82. }else if ($userDutyCheck&&$userDutyCheck->type=='登出'){
  83. event(new ClockoutEvent($userDutyCheck));
  84. }
  85. //正常情况
  86. $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow."%")->where('user_id',$userDetail->user_id)->first();
  87. if ($laborReport&&$userDutyCheck->type=='登出'){
  88. LaborReport::updateLaborReportData($laborReport,$userDutyCheck);
  89. $this->log(__METHOD__,"更新临时工报表记录__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
  90. }
  91. if ($userDutyCheck&&$userDutyCheck->error==true)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  92. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  93. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  94. $group_name=$userDutyCheck->userWorkgroup['name'];
  95. $laravelEchoPrefix = config('database.redis.options.prefix');
  96. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  97. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  98. }
  99. //去往登记资料页面
  100. public function createUserDetail($mobile_phone){
  101. $userWorkgroupID=session("userWorkgroupID");
  102. $laborCompanies=LaborCompany::select('id','name')->get();
  103. return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
  104. }
  105. //七天未打卡去往选择劳务所页面
  106. public function updateUserDetail($mobile_phone){
  107. $userWorkgroupID=session("userWorkgroupID");
  108. $laborCompanies=LaborCompany::select('id','name')->get();
  109. return view('personnel/checking-in/updateUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
  110. }
  111. //提交修改资料
  112. public function storeUpdateUserDetail(Request $request){
  113. $this->validator($request)->validate();
  114. $mobile_phone=$request->input('mobile_phone');
  115. $userWorkgroupID=$request->input('userWorkgroupID');
  116. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  117. if (!$userDetail)return view('exception.404',['error'=>'临时工信息不存在!']);
  118. $labor_company_id=$request->input('labor_company_id');
  119. $userLabor=UserLabor::where('user_id',$userDetail->user_id)->first();
  120. $userLabor->update([
  121. 'labor_company_id'=>$labor_company_id,
  122. ]);
  123. $this->log(__METHOD__,"更改临时工劳务所信息".__FUNCTION__,json_encode($userLabor),Auth::user()['id']);
  124. $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
  125. if ($userDutyCheck&&$userDutyCheck->type=='登入'){
  126. event(new ClockinEvent($userDutyCheck));
  127. }else if ($userDutyCheck&&$userDutyCheck->type=='登出'){
  128. event(new ClockoutEvent($userDutyCheck));
  129. }
  130. if ($userDutyCheck&&$userDutyCheck->error==true)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  131. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  132. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  133. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  134. $group_name=$userDutyCheck->userWorkgroup['name'];
  135. $laravelEchoPrefix = config('database.redis.options.prefix');
  136. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  137. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  138. }
  139. //提交登记资料
  140. public function storeUserDetail(Request $request){
  141. $this->validator($request)->validate();
  142. $mobile_phone=$request->input('mobile_phone');
  143. $full_name=$request->input('full_name');
  144. $identity_number=$request->input('identity_number');
  145. $userWorkgroupID=$request->input('userWorkgroupID');
  146. $user=new User([
  147. 'name'=>$mobile_phone,
  148. 'password'=>Uuid::uuid1(),
  149. ]);
  150. $user->save();
  151. $userDetail=new UserDetail([
  152. 'user_id'=>$user->id,
  153. 'full_name'=>$full_name,
  154. 'identity_number'=>$identity_number,
  155. 'gender'=>$request->input('gender'),
  156. 'mobile_phone'=>$mobile_phone,
  157. 'type'=>'临时工',
  158. ]);
  159. $userDetail->save();
  160. $labor_company_id=$request->input('labor_company_id');
  161. $userLabor=new UserLabor([
  162. 'user_id'=>$user->id,
  163. 'labor_company_id'=>$labor_company_id,
  164. ]);
  165. $userLabor->save();
  166. $userDutyCheck=$this->dutyCheck($user->id,$userWorkgroupID);
  167. if ($userDutyCheck&&$userDutyCheck->type=='登入'){
  168. event(new ClockinEvent($userDutyCheck));
  169. }else if ($userDutyCheck&&$userDutyCheck->type=='登出'){
  170. event(new ClockoutEvent($userDutyCheck));
  171. }
  172. if ($userDutyCheck&&$userDutyCheck->error==true)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  173. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  174. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  175. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  176. $group_name=$userDutyCheck->userWorkgroup['name'];
  177. $laravelEchoPrefix = config('database.redis.options.prefix');
  178. return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  179. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  180. }
  181. //根据用户提交打卡记录
  182. public function dutyCheck($user_id,$userWorkgroupID){
  183. $userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  184. if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']){
  185. $user=User::find($user_id);
  186. $user->userWorkgroups()->sync([$userWorkgroupID]);
  187. }
  188. $date=date('Y-m-d H:i:s');
  189. $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode([$user_id,$userWorkgroupID,$date]));
  190. $userDutyCheck=new UserDutyCheck([
  191. 'user_id'=>$user_id,
  192. 'checked_at'=>$date,
  193. 'source'=>'正常',
  194. 'verify_user_id'=>'',
  195. 'workgroup_id'=>$userWorkgroupID,
  196. ]);
  197. if (!$userDutyCheckOld){
  198. $userDutyCheck->type="登入";
  199. $userDutyCheck->save();
  200. return $userDutyCheck;
  201. }
  202. $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
  203. $thisDate=Carbon::parse($date);
  204. $diffDate=$thisDate->diffInMinutes($lastDate);
  205. // if ($userDutyCheckOld->type=="登出"&&$diffDate<7*1440){
  206. // $userDutyCheck->type="登入";
  207. // $userDutyCheck->verify_user_id=0;
  208. // $userDutyCheck->save();
  209. // return $userDutyCheck;
  210. // }
  211. if($diffDate<=5){
  212. $userDutyCheck->error=true;//重复打卡
  213. if($userWorkgroupID!=$userDutyCheckOld['workgroup_id']&&$userDutyCheckOld->type=='登入'){
  214. if ($userDutyCheck->error){
  215. $userDutyCheck->error=false;
  216. }
  217. $userDutyCheckOld->checked_at=$date;
  218. $userDutyCheckOld->verify_user_id=null;
  219. $userDutyCheckOld->workgroup_id=$userWorkgroupID;
  220. $userDutyCheckOld->group_user_id=null;
  221. $userDutyCheckOld->update();
  222. return $userDutyCheckOld;
  223. }
  224. return $userDutyCheck;
  225. }
  226. if ($userDutyCheckOld->type=="登入"){
  227. switch ($diffDate){
  228. case $diffDate<=20:
  229. $userDutyCheck->type="登入";
  230. $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
  231. break;
  232. case $diffDate>=1380:
  233. $userDutyCheck->type=="登入";
  234. break;
  235. default:
  236. $userDutyCheck->type="登出";
  237. $userDutyCheck->verify_user_id=0;
  238. }
  239. }
  240. if ($userDutyCheckOld->type=="登出"){
  241. switch ($diffDate){
  242. case $diffDate<=20:
  243. $userDutyCheck->type="登出";
  244. $userDutyCheck->verify_user_id=0;
  245. $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
  246. break;
  247. default:
  248. $userDutyCheck->type="登入";
  249. }
  250. }
  251. if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']&&$userDutyCheckOld->type=="登入"&&$userDutyCheck->type="登出"){
  252. if ($diffDate>=1380){
  253. $userDutyCheck->type="登入";
  254. }else{
  255. $userDutyCheck->workgroup_id=$userDutyCheckOld['workgroup_id'];
  256. }
  257. }
  258. $userDutyCheck->save();
  259. return $userDutyCheck;
  260. }
  261. public function validator(Request $request){
  262. $validator=Validator::make($request->input(),[
  263. 'full_name'=>['filled'],
  264. 'userWorkgroupID'=>['filled'],
  265. 'gender'=>['filled'],
  266. 'mobile_phone'=>['required','integer','digits:11'],
  267. 'identity_number' => ['filled','identity_cards','unique:user_details,identity_number'],
  268. ],[
  269. 'unique'=>':attribute 已经存在,不能重复!',
  270. 'filled' => ':attribute 不能为空',
  271. 'required'=>':attribute 为必填项',
  272. 'integer'=>':attribute 数字类型',
  273. 'digits'=>':attribute 必须是11位',
  274. ],[
  275. 'full_name'=>'姓名',
  276. 'userWorkgroupID'=>'工作组ID',
  277. 'gender'=>'性别',
  278. 'mobile_phone'=>'手机号',
  279. 'identity_number' => '身份证号',
  280. ]);
  281. return $validator;
  282. }
  283. }