UserDutyCheckController.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\LaborCompany;
  4. use App\LaborReport;
  5. use App\User;
  6. use App\UserDetail;
  7. use App\UserDutyCheck;
  8. use App\UserLabor;
  9. use App\UserToken;
  10. use App\UserWorkgroup;
  11. use App\Warehouse;
  12. use Carbon\Carbon;
  13. use Endroid\QrCode\QrCode;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Http\Response;
  16. use Illuminate\Support\Facades\Cache;
  17. use Illuminate\Support\Facades\Validator;
  18. use Ramsey\Uuid\Uuid;
  19. class UserDutyCheckController extends Controller
  20. {
  21. public function goGetQRCode(){
  22. $warehouses=Warehouse::get();
  23. return view("personnel/checking-in/getQRcode",compact('warehouses'));
  24. }
  25. //二维码刷新时间
  26. public function qrCode_refresh_time($userWorkgroups,$beforeTime){
  27. $qrCode_refresh=config('hr.qrCode_refresh');
  28. if (!Cache::has('last_refresh_date') || Cache::get('last_refresh_date')<date('Y-m-d H:i:s')){
  29. $last_refresh_date=date('Y-m-d H:i:s',strtotime('+'.$qrCode_refresh.'second'));
  30. Cache::put('last_refresh_date',$last_refresh_date);
  31. return $this->flushQRCode($userWorkgroups);
  32. }
  33. if ($beforeTime==Cache::get('last_refresh_date')){
  34. //刷新 更新cache
  35. $last_refresh_date=$beforeTime.strtotime('+'.$qrCode_refresh.'second');
  36. Cache::put('last_refresh_date',$last_refresh_date);
  37. return $this->flushQRCode($userWorkgroups);
  38. }
  39. //每次刷新都标记一个cache 新建 每次刷新前判断这个标记时间
  40. //直接去本地获取二维码
  41. return $this->getQRCode($userWorkgroups);
  42. }
  43. //刷新二维码
  44. public function flushQRCode($userWorkgroups){
  45. foreach ($userWorkgroups as $userWorkgroup){
  46. $url=url("personnel/checking-in/userDutyCheck/clock");
  47. $url=$url."?userWorkgroupID=".$userWorkgroup->id;
  48. $qrCode=new QrCode($url);
  49. if ($userWorkgroup->id){
  50. $fileURL=base_path('public/images/QRCodeIMG/'.$userWorkgroup->id.'.png');
  51. $qrCode->writeFile($fileURL);
  52. $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
  53. }
  54. }
  55. return $userWorkgroups;
  56. }
  57. //获取二维码
  58. public function getQRCode($userWorkgroups){
  59. foreach ($userWorkgroups as $userWorkgroup){
  60. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  61. if ($qrCode_refresh_everyday){
  62. $date=md5(date('Y-m-d'));
  63. $url=url("personnel/checking-in/userDutyCheck/clock?key=").$date;
  64. $url=$url."&&userWorkgroupID=".$userWorkgroup->id;
  65. }else{
  66. $url=url("personnel/checking-in/userDutyCheck/clock");
  67. $url=$url."?userWorkgroupID=".$userWorkgroup->id;
  68. }
  69. $qrCode=new QrCode($url);
  70. if ($userWorkgroup->id){
  71. $fileURL=base_path('public/images/QRCodeIMG/'.$userWorkgroup->id.'.png');
  72. if (file_exists($fileURL)){
  73. $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
  74. continue;
  75. }
  76. $qrCode->writeFile($fileURL);
  77. $userWorkgroup->url=url('images/QRCodeIMG/'.$userWorkgroup->id.'.png');
  78. }
  79. }
  80. return $userWorkgroups;
  81. }
  82. //进入刷新二维码页面
  83. public function refreshQRCode(Request $request){
  84. $beforeTime=$request->input('beforeTime');
  85. $warehouseId=$request->input('warehouseId');
  86. $userWorkgroups=UserWorkgroup::where('warehouse_id',$warehouseId)->get();
  87. $userWorkgroups=$this->qrCode_refresh_time($userWorkgroups,$beforeTime);
  88. if (!$userWorkgroups)return view('exception.404',['error'=>'未找到工作组!']);
  89. return ['userWorkgroups'=>$userWorkgroups,'last_refresh_date'=>Cache::get('last_refresh_date'),];
  90. }
  91. //第一次进入二维码显示页面
  92. public function QRCode(Request $request){
  93. $warehouseId=$request->input('warehouseId');
  94. $userWorkgroups=UserWorkgroup::where('warehouse_id',$warehouseId)->get();
  95. $beforeTime=date('Y-m-d H:i:s');
  96. $userWorkgroups=$this->qrCode_refresh_time($userWorkgroups,$beforeTime);
  97. if (!$userWorkgroups)return view('exception.404',['error'=>'未找到工作组!']);
  98. return view('personnel/checking-in/QRcode',['warehouseId'=>$warehouseId,'userWorkgroups'=>$userWorkgroups,'last_refresh_date'=>Cache::get('last_refresh_date'),]);
  99. }
  100. //校验二维码进入打卡页面
  101. public function clock(Request $request){
  102. $userWorkgroupID=$request->input('userWorkgroupID');
  103. $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
  104. if ($qrCode_refresh_everyday){
  105. $key=$request->input('key');
  106. if (!$key) return "二维码失效!";
  107. $date=md5(date('Y-m-d'));
  108. if ($key!=$date) return "二维码失效!";
  109. }
  110. $userLaborToken=$request->cookie('userLaborToken');
  111. if ($userLaborToken && Cache::has('tokenStr_'.$userLaborToken)) {
  112. $user_id=Cache::get('tokenStr_'.$userLaborToken);
  113. $userDetail=UserDetail::find($user_id);
  114. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  115. if ($userWorkgroupID){
  116. $user=UserToken::getUser($userLaborToken);
  117. $user->userWorkgroups()->sync([$userWorkgroupID]);
  118. }
  119. $userDutyCheck=$this->dutyCheck($userDetail->user_id);
  120. if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  121. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  122. $userWorkgroups=$userDetail->user->userWorkgroups();
  123. if($userWorkgroups->count()>0)
  124. $group_name=$userDetail->user->userWorkgroups->first()['name'];
  125. $laravelEchoPrefix = config('database.redis.options.prefix');
  126. 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]);
  127. }
  128. return view("personnel/checking-in/clock",compact('userWorkgroupID'));
  129. }
  130. //提交打卡
  131. public function storeClock(Request $request){
  132. $mobile_phone=$request->input('mobile_phone');
  133. $userWorkgroupID=$request->input('userWorkgroupID');
  134. $this->validator($request)->validate();
  135. $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
  136. if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  137. $user=User::find($userDetail->user_id);
  138. if (Cache::has('tokenUser_'.$user->id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  139. if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
  140. $userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  141. $date=date('Y-m-d H:i:s');
  142. $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
  143. $thisDate=Carbon::parse($date);
  144. $diffDate=$thisDate->diffInMinutes($lastDate);
  145. //七天未登录从新选择劳务所
  146. if ($diffDate>7*1440){
  147. return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
  148. }
  149. $userDutyCheck=$this->dutyCheck($userDetail->user_id);
  150. var_dump($userDutyCheck->type);
  151. if ($userDutyCheck->type=='登入'){
  152. $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
  153. }
  154. if ($userDutyCheck->type=='登出'){
  155. $this->updateLaborReportData($userDetail,$userDutyCheck);
  156. }
  157. if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  158. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  159. $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
  160. $group_name=$userDetail->user->userWorkgroups->first()['name'];
  161. $laravelEchoPrefix = config('database.redis.options.prefix');
  162. 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])
  163. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  164. }
  165. //去往登记资料页面
  166. public function createUserDetail($mobile_phone){
  167. $userWorkgroupID=session("userWorkgroupID");
  168. $laborCompanies=LaborCompany::select('id','name')->get();
  169. return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
  170. }
  171. //七天未打卡去往选择劳务所页面
  172. public function updateUserDetail($mobile_phone){
  173. $userWorkgroupID=session("userWorkgroupID");
  174. $laborCompanies=LaborCompany::select('id','name')->get();
  175. return view('personnel/checking-in/updateUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
  176. }
  177. //提交修改资料
  178. public function storeUpdateUserDetail(Request $request){
  179. $this->validator($request)->validate();
  180. $mobile_phone=$request->input('mobile_phone');
  181. $userWorkgroupID=$request->input('userWorkgroupID');
  182. $user=User::where('name',$mobile_phone)->first();
  183. $userDetail=UserDetail::where('user_id',$user->id)->first();
  184. if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
  185. $laborCompany=$request->input('laborCompany');
  186. $labor_company_id=LaborCompany::where('name',$laborCompany)->value('id');
  187. $userLabor=UserLabor::where('user_id',$user->id)->first();
  188. $userLabor->update([
  189. 'user_id'=>$user->id,
  190. 'labor_company_id'=>$labor_company_id,
  191. ]);
  192. $userDutyCheck=$this->dutyCheck($user->id);
  193. //添加临时工报表数据
  194. $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
  195. if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  196. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  197. $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
  198. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  199. $group_name=$userDetail->user->userWorkgroups->first()['name'];
  200. $laravelEchoPrefix = config('database.redis.options.prefix');
  201. 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])
  202. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  203. }
  204. //提交登记资料
  205. public function storeUserDetail(Request $request){
  206. $this->validator($request)->validate();
  207. $mobile_phone=$request->input('mobile_phone');
  208. $full_name=$request->input('full_name');
  209. $identity_number=$request->input('identity_number');
  210. $userWorkgroupID=$request->input('userWorkgroupID');
  211. $user=new User([
  212. 'name'=>$mobile_phone,
  213. 'password'=>Uuid::uuid1(),
  214. ]);
  215. $user->save();
  216. if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
  217. $userDetail=new UserDetail([
  218. 'user_id'=>$user->id,
  219. 'full_name'=>$full_name,
  220. 'identity_number'=>$identity_number,
  221. 'gender'=>$request->input('gender'),
  222. 'mobile_phone'=>$mobile_phone,
  223. 'type'=>'临时工',
  224. ]);
  225. $userDetail->save();
  226. $laborCompany=$request->input('laborCompany');
  227. $labor_company_id=LaborCompany::where('name',$laborCompany)->value('id');
  228. $userLabor=new UserLabor([
  229. 'user_id'=>$user->id,
  230. 'labor_company_id'=>$labor_company_id,
  231. ]);
  232. $userLabor->save();
  233. $userDutyCheck=$this->dutyCheck($user->id);
  234. $this->createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck);
  235. if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
  236. if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  237. $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
  238. $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
  239. $group_name=$userDetail->user->userWorkgroups->first()['name'];
  240. $laravelEchoPrefix = config('database.redis.options.prefix');
  241. 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])
  242. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  243. }
  244. //根据用户提交打卡记录
  245. public function dutyCheck($user_id){
  246. $userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
  247. $date=date('Y-m-d H:i:s');
  248. $userDutyCheck=new UserDutyCheck([
  249. 'user_id'=>$user_id,
  250. 'checked_at'=>$date,
  251. 'source'=>'正常',
  252. 'verify_user_id'=>'',
  253. ]);
  254. if (!$userDutyCheckOld){
  255. $userDutyCheck->type="登入";
  256. $userDutyCheck->save();
  257. $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode($userDutyCheck));
  258. return $userDutyCheck;
  259. }
  260. $lastDate=Carbon::parse($userDutyCheckOld->checked_at);
  261. $thisDate=Carbon::parse($date);
  262. $diffDate=$thisDate->diffInMinutes($lastDate);
  263. if ($diffDate>7*1440){
  264. $userDutyCheck->type="登入";
  265. $userDutyCheck->save();
  266. return $userDutyCheck;
  267. }
  268. if ($diffDate>=1380&&$diffDate<7*1440){
  269. $userDutyCheck->verify_user_id=0;
  270. return $userDutyCheck;
  271. }
  272. if($diffDate<=5){
  273. $userDutyCheck->error=true;
  274. return $userDutyCheck;
  275. }
  276. if ($userDutyCheckOld->type=="登入"){
  277. switch ($diffDate){
  278. case $diffDate<=20:
  279. $userDutyCheck->type="登入";
  280. break;
  281. case $diffDate>=1380:
  282. $userDutyCheck->type="登入";
  283. break;
  284. default:
  285. $userDutyCheck->type="登出";
  286. }
  287. }
  288. if ($userDutyCheckOld->type=="登出"){
  289. switch ($diffDate){
  290. case $diffDate<=20:
  291. $userDutyCheck->type="登出";
  292. break;
  293. default:
  294. $userDutyCheck->type="登入";
  295. }
  296. }
  297. $userDutyCheck->save();
  298. $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode($userDutyCheck));
  299. return $userDutyCheck;
  300. }
  301. //添加临时工报表数据
  302. public function createLaborReportData($userDetail,$userWorkgroupID,$userDutyCheck){
  303. $user_id=$userDetail['user_id'];
  304. $name=$userDetail['full_name'];
  305. $mobile_phone=$userDetail['mobile_phone'];
  306. $identity_number=$userDetail['identity_number'];
  307. $labor_company_id=UserLabor::where('user_id',$user_id)->value('labor_company_id');
  308. $labor_company=LaborCompany::where('id',$labor_company_id)->value('name');
  309. if ($userDutyCheck->type=='登入'){
  310. $check_in_at=$userDutyCheck['checked_at'];
  311. }
  312. $laborReport=new LaborReport([
  313. 'enter_number'=>Uuid::uuid1(),
  314. 'user_workgroup_id'=>$userWorkgroupID,
  315. 'user_id'=>$user_id,
  316. 'name'=>$name,
  317. 'mobile_phone'=>$mobile_phone,
  318. 'identity_number'=>$identity_number,
  319. 'labor_company'=>$labor_company,
  320. 'check_in_at'=>$check_in_at,
  321. ]);
  322. $laborReport->save();
  323. $number_id=$laborReport->id;
  324. $enter_number=$userWorkgroupID.date ("ymd").str_pad($number_id>99999?$number_id%99999:$number_id,4,"0",STR_PAD_LEFT);
  325. $laborReport->enter_number=$enter_number;
  326. $laborReport->update();
  327. return;
  328. }
  329. //修改临时工报表数据
  330. public function updateLaborReportData($userDetail,$userDutyCheck){
  331. $check_in_at=UserDutyCheck::where('user_id',$userDetail->user_id)->where('type','登入')->value('checked_at');
  332. var_dump($check_in_at);
  333. $laborReport=LaborReport::where('check_in_at',$check_in_at)->first();
  334. var_dump($laborReport);
  335. $laborReport['check_out_at']=$userDutyCheck['checked_at'];
  336. var_dump($laborReport['check_out_at']);
  337. $checkInDate=Carbon::parse($check_in_at);
  338. $checkOutDate=Carbon::parse($userDutyCheck->checked_at);
  339. $diffDate=$checkOutDate->diffInHours($checkInDate);
  340. dd($diffDate);
  341. $laborReport['working_duration']=$diffDate;
  342. $laborReport->save();
  343. return;
  344. }
  345. public function validator(Request $request){
  346. $validator=Validator::make($request->input(),[
  347. 'full_name'=>['filled'],
  348. 'gender'=>['filled'],
  349. 'mobile_phone'=>['required','integer','digits:11'],
  350. 'identity_number' => ['identitycards'],
  351. ],[],[]);
  352. return $validator;
  353. }
  354. }