UserDutyCheckController.php 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Events\ClockinEvent;
  4. use App\LaborCompany;
  5. use App\LaborReport;
  6. use App\Services\LaborReportService;
  7. use App\User;
  8. use App\UserDetail;
  9. use App\UserDutyCheck;
  10. use App\UserLabor;
  11. use App\UserWorkgroup;
  12. use Carbon\Carbon;
  13. use Illuminate\Http\Request;
  14. use Illuminate\Support\Facades\Auth;
  15. use Illuminate\Support\Facades\Cache;
  16. use Illuminate\Support\Facades\Validator;
  17. use Ramsey\Uuid\Uuid;
  18. class UserDutyCheckController extends Controller
  19. {
  20. function __construct()
  21. {
  22. app()->bind('LaborReportService', LaborReportService::class);
  23. }
  24. //校验二维码进入进出场打卡页面
  25. public function importAndExportClock(Request $request)
  26. {
  27. $importAndExportQRCodeType = $request->input('importAndExportQRCodeType');
  28. $qrCode_refresh_everyday = config('hr.qrCode_refresh_everyday');
  29. $qrCode_refresh = config('hr.qrCode_refresh');
  30. if ($qrCode_refresh_everyday) {
  31. $key = $request->input('key');
  32. if (!$key) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  33. $date = md5(date('Y-m-d'));
  34. if ($key != $date) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  35. }
  36. if ($qrCode_refresh) {
  37. $key = $request->input('key');
  38. if (!$key) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  39. $date = date('Y-m-d H:i:s');
  40. if ($key < $date) return "<h1 style='color: red;text-align:center'>当前二维码失效,请重新扫码!</h1>";
  41. }
  42. $userLaborToken = $request->cookie('userLaborToken');
  43. $user_id = Cache::get('dutyCheckTokenStr_'.$userLaborToken);
  44. if (!$user_id) $this->log(__METHOD__, "进出场扫码(未绑定设备)__" . __FUNCTION__, json_encode($importAndExportQRCodeType));
  45. if ($userLaborToken && $user_id) {
  46. $userDetail = UserDetail::find($user_id);
  47. if($userDetail){
  48. if($importAndExportQRCodeType=='import') return redirect('personnel/checking-in/userDutyCheck/updateUserLaborCompanies/' . $userDetail->mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
  49. $userDutyCheck = $this->importAndExportDutyCheck($user_id, $importAndExportQRCodeType);
  50. if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  51. if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  52. if ($userDutyCheck && $userDutyCheck->export == true) return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  53. if ($userDutyCheck&& !$userDutyCheck->id) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  54. $laborReportService = app('LaborReportService');
  55. $errorMessage = $laborReportService->makeOrChangeLaborReportByUserDutyCheck($userDutyCheck, $importAndExportQRCodeType);
  56. if ($errorMessage) return $errorMessage;
  57. $laravelEchoPrefix = config('database.redis.options.prefix');
  58. $log=[
  59. 'importAndExportQRCodeType'=>$importAndExportQRCodeType,
  60. 'userDetail'=>$userDetail,
  61. ];
  62. $this->log(__METHOD__, "进出场扫码__" . __FUNCTION__, json_encode($log));
  63. return response()->view('personnel/checking-in/importAndExportSuccess', ['full_name' => $userDetail->full_name, 'checked_at' => $userDutyCheck->checked_at, 'type' => $userDutyCheck->type, 'laravelEchoPrefix' => $laravelEchoPrefix]);
  64. }
  65. }
  66. return view("personnel/checking-in/importAndExportClock", compact('importAndExportQRCodeType'));
  67. }
  68. //输入手机号提交进场打卡
  69. public function storeClock(Request $request)
  70. {
  71. $importAndExportQRCodeType = $request->input('importAndExportQRCodeType');
  72. $mobile_phone = $request->input('mobile_phone');
  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("importAndExportQRCodeType", $importAndExportQRCodeType);
  76. if (Cache::has('dutyCheckTokenUser_' . $userDetail->user_id)) return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
  77. if($importAndExportQRCodeType=='import') return redirect('personnel/checking-in/userDutyCheck/updateUserLaborCompanies/' . $userDetail->mobile_phone)->with("importAndExportQRCodeType", $importAndExportQRCodeType);
  78. $userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id, $importAndExportQRCodeType);
  79. if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  80. if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  81. if ($userDutyCheck && $userDutyCheck->export == true) return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  82. if ($userDutyCheck&& !$userDutyCheck->id) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  83. //$userLaborToken = $userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  84. $laborReportService = app('LaborReportService');
  85. $errorMessage = $laborReportService->makeOrChangeLaborReportByUserDutyCheck($userDutyCheck, $importAndExportQRCodeType);
  86. if ($errorMessage) return $errorMessage;
  87. $laravelEchoPrefix = config('database.redis.options.prefix');
  88. return response()->view('personnel/checking-in/importAndExportSuccess', ['full_name' => $userDetail->full_name, 'checked_at' => $userDutyCheck->checked_at, 'type' => $userDutyCheck->type, 'laravelEchoPrefix' => $laravelEchoPrefix]);
  89. // ->cookie('userLaborToken', $userLaborToken, config('users.token_check_in_expire_minutes'), '/')
  90. }
  91. //根据用户提交进出场打卡记录
  92. public function importAndExportDutyCheck($user_id,$importAndExportQRCodeType)
  93. {
  94. $dateNow = Carbon::now()->format('Y-m-d');
  95. $userDutyCheckOld = UserDutyCheck::query()->with('laborReport')->where('user_id', $user_id)->where('checked_at','like',$dateNow.'%')->orderBy('id','desc')->first();
  96. $date = date('Y-m-d H:i:s');
  97. $this->log(__METHOD__, "提交打卡记录__" . __FUNCTION__, json_encode([$user_id, $date]));
  98. $userDutyCheck = new UserDutyCheck([
  99. 'user_id' => $user_id,
  100. 'checked_at' => $date,
  101. 'source' => '正常',
  102. ]);
  103. //跨天登出情况
  104. if (!$userDutyCheckOld) {
  105. //当前日期的前一天
  106. $yesterday = Carbon::yesterday()->format('Y-m-d');
  107. $userDutyCheckYesterday = UserDutyCheck::query()->with('laborReport')->where('user_id', $user_id)->where('checked_at','like', $yesterday.'%')->orderBy('id','desc')->first();
  108. if ($importAndExportQRCodeType && $importAndExportQRCodeType == 'export') {
  109. if ($userDutyCheckYesterday && $userDutyCheckYesterday->type == '登入') {
  110. $userDutyCheck->verify_user_id = $userDutyCheckYesterday->verify_user_id;
  111. $userDutyCheck->type = '登出';
  112. $userDutyCheck->save();
  113. return $userDutyCheck;
  114. }
  115. }
  116. if ($importAndExportQRCodeType && $importAndExportQRCodeType == 'import') {
  117. if ($userDutyCheckYesterday && $userDutyCheckYesterday->type == '登入'&&$userDutyCheckYesterday->laborReport) {
  118. $userDutyCheck->import = true;//已入场的不能再入场
  119. return $userDutyCheck;
  120. }
  121. }
  122. if ($importAndExportQRCodeType == 'export') {
  123. $userDutyCheck->isNotImport = true;//还未进场,不可出场
  124. return $userDutyCheck;
  125. }
  126. $userDutyCheck->type = "登入";
  127. $userDutyCheck->save();
  128. $this->log(__METHOD__, "创建打卡记录" . __FUNCTION__, json_encode($userDutyCheck));
  129. return $userDutyCheck;
  130. }
  131. if ($importAndExportQRCodeType && $importAndExportQRCodeType == 'import') {
  132. if ($userDutyCheckOld->type == '登入'&&$userDutyCheckOld->laborReport) {
  133. $userDutyCheck->import = true;//已入场的不能再入场
  134. return $userDutyCheck;
  135. }
  136. $userDutyCheck->type = '登入';
  137. }
  138. if ($importAndExportQRCodeType && $importAndExportQRCodeType == 'export') {
  139. if ($userDutyCheckOld->type == '登出') {
  140. $userDutyCheck->export = true;//已出场的不能再出场
  141. return $userDutyCheck;
  142. }
  143. $userDutyCheck->verify_user_id = $userDutyCheckOld->verify_user_id;
  144. $userDutyCheck->type = '登出';
  145. }
  146. $userDutyCheck->save();
  147. $this->log(__METHOD__, "创建打卡记录" . __FUNCTION__, json_encode($userDutyCheck));
  148. return $userDutyCheck;
  149. }
  150. //去往登记资料页面
  151. public function createUserDetail($mobile_phone)
  152. {
  153. $importAndExportQRCodeType = session("importAndExportQRCodeType");
  154. $laborCompanies = LaborCompany::select('id', 'name')->get();
  155. return view('personnel/checking-in/createUserDetail', ['mobile_phone' => $mobile_phone, 'importAndExportQRCodeType' => $importAndExportQRCodeType, 'laborCompanies' => $laborCompanies]);
  156. }
  157. //未打卡去往选择劳务所页面
  158. public function updateUserLaborCompanies($mobile_phone)
  159. {
  160. $importAndExportQRCodeType = session("importAndExportQRCodeType");
  161. $laborCompanies = LaborCompany::select('id', 'name')->get();
  162. return view('personnel/checking-in/updateUserLaborCompanies', ['mobile_phone' => $mobile_phone, 'importAndExportQRCodeType' => $importAndExportQRCodeType, 'laborCompanies' => $laborCompanies]);
  163. }
  164. //打卡修改临时工劳务所信息并生成进场记录 AndMakeEnterRecord
  165. public function storeUpdateUserLaborCompanies(Request $request)
  166. {
  167. $this->updateValidator($request)->validate();
  168. $importAndExportQRCodeType = $request->input('importAndExportQRCodeType');
  169. $mobile_phone = $request->input('mobile_phone');
  170. $userDetail = UserDetail::query()->where('mobile_phone', $mobile_phone)->first();
  171. if (!$userDetail) return view('exception.404', ['error' => '临时工信息不存在!']);
  172. $labor_company_id = $request->input('labor_company_id');
  173. $userLabor = UserLabor::query()->where('user_id', $userDetail->user_id)->first();
  174. $userLabor->update([
  175. 'labor_company_id' => $labor_company_id,
  176. ]);
  177. $this->log(__METHOD__, "更改临时工劳务所信息" . __FUNCTION__, json_encode($userLabor), Auth::user()['id']);
  178. $userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id,$importAndExportQRCodeType);
  179. if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  180. if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  181. if ($userDutyCheck && $userDutyCheck->export == true) return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  182. if ($userDutyCheck&& !$userDutyCheck->id) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  183. $userLaborToken = $userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  184. $laborReportService = app('LaborReportService');
  185. $laborReportService->makeOrChangeLaborReportByUserDutyCheck($userDutyCheck, $importAndExportQRCodeType);
  186. $laravelEchoPrefix = config('database.redis.options.prefix');
  187. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  188. ->cookie('userLaborToken', $userLaborToken, config('users.token_check_in_expire_minutes'), '/');
  189. }
  190. public function updateValidator(Request $request)
  191. {
  192. $updateValidator = Validator::make($request->input(), [
  193. 'mobile_phone' => ['required', 'integer', 'digits:11'],
  194. 'labor_company_id' => ['filled'],
  195. ], [
  196. 'filled' => ':attribute 不能为空',
  197. 'required' => ':attribute 为必填项',
  198. 'integer' => ':attribute 数字类型',
  199. 'digits' => ':attribute 必须是11位',
  200. ], [
  201. 'mobile_phone' => '手机号',
  202. 'labor_company_id' => '劳务所',
  203. ]);
  204. return $updateValidator;
  205. }
  206. //打卡创建临时工资料并生成进场记录
  207. public function storeUserDetail(Request $request)
  208. {$this->validator($request)->validate();
  209. $importAndExportQRCodeType = $request->input('importAndExportQRCodeType');
  210. $mobile_phone = $request->input('mobile_phone');
  211. $full_name = $request->input('full_name');
  212. $identity_number = $request->input('identity_number');
  213. $gender = $request->input('gender');
  214. $labor_company_id = $request->input('labor_company_id');
  215. $user = new User([
  216. 'name' => $mobile_phone,
  217. 'password' => Uuid::uuid1(),
  218. ]);
  219. $user->save();
  220. $userDetail = new UserDetail([
  221. 'user_id' => $user->id,
  222. 'full_name' => $full_name,
  223. 'identity_number' => $identity_number,
  224. 'gender' => $gender,
  225. 'mobile_phone' => $mobile_phone,
  226. 'type' => '临时工',
  227. ]);
  228. $userDetail->save();
  229. $userDetail->updateUserName();
  230. $userLabor = new UserLabor([
  231. 'user_id' => $user->id,
  232. 'labor_company_id' => $labor_company_id,
  233. ]);
  234. $userLabor->save();
  235. $laborReportService = app('LaborReportService');
  236. $userDutyCheck=$this->importAndExportDutyCheck($userDetail->user_id,$importAndExportQRCodeType);
  237. if ($userDutyCheck && $userDutyCheck->isNotImport == true) return "<h1 style='color: darkred;text-align:center'>当前还未入场,不可出场!</h1>";
  238. if ($userDutyCheck && $userDutyCheck->import == true) return "<h1 style='color: darkred;text-align:center'>您已入场,不可再次入场!</h1>";
  239. if ($userDutyCheck && $userDutyCheck->export == true) return "<h1 style='color: darkred;text-align:center'>您已出场,不可再次出场!!</h1>";
  240. if ($userDutyCheck&& !$userDutyCheck->id) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  241. $laborReportService->makeLaborReportByUserDutyCheck($userDutyCheck);
  242. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  243. Controller::logS(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($userDetail));
  244. $laravelEchoPrefix = config('database.redis.options.prefix');
  245. return response()->view('personnel/checking-in/importAndExportSuccess',['full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at,'type'=>$userDutyCheck->type,'laravelEchoPrefix'=>$laravelEchoPrefix])
  246. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  247. }
  248. public function validator(Request $request)
  249. {
  250. $validator = Validator::make($request->input(), [
  251. 'full_name' => ['filled'],
  252. 'gender' => ['filled'],
  253. 'mobile_phone' => ['required', 'integer', 'digits:11'],
  254. 'identity_number' => ['filled', 'identity_cards', 'unique:user_details,identity_number'],
  255. 'labor_company_id' => ['filled'],
  256. ], [
  257. 'unique' => ':attribute 已经存在,不能重复!',
  258. 'filled' => ':attribute 不能为空',
  259. 'required' => ':attribute 为必填项',
  260. 'integer' => ':attribute 数字类型',
  261. 'digits' => ':attribute 必须是11位',
  262. ], [
  263. 'full_name' => '姓名',
  264. 'gender' => '性别',
  265. 'mobile_phone' => '手机号',
  266. 'identity_number' => '身份证号',
  267. 'labor_company_id' => '劳务所',
  268. ]);
  269. return $validator;
  270. }
  271. //扫工作组二维码
  272. public function clock(Request $request)
  273. {
  274. $userWorkgroupID = $request->input('userWorkgroupID');
  275. $userLaborToken = $request->cookie('userLaborToken');
  276. $user_id = Cache::get('dutyCheckTokenStr_'.$userLaborToken);
  277. if (!$user_id)$this->log(__METHOD__, "进组扫码(未绑定设备)__" . __FUNCTION__, json_encode($userWorkgroupID));
  278. if ($userLaborToken && $user_id) {
  279. $dateNow = Carbon::now()->format('Y-m-d');
  280. $userDutyCheck = UserDutyCheck::where('user_id', $user_id)->where('checked_at', 'like', $dateNow. '%')->orderBy('id', 'desc')->first();
  281. if (!$userDutyCheck['verify_user_id']) return "<h1 style='color: red;text-align:center'>进场门卫还未审核,暂无法进组!</h1>";
  282. if ($userDutyCheck->type == '登出') return "<h1 style='color: red;text-align:center'>进场是否未打卡?如若未打,请先返回打进场卡!</h1>";
  283. $html=$this->updateLaborReport($user_id,$userWorkgroupID);
  284. if ($html)return $html;
  285. $log=[
  286. 'userWorkgroupID'=>$userWorkgroupID,
  287. 'user_id'=>$user_id,
  288. ];
  289. $this->log(__METHOD__, "进组扫码__" . __FUNCTION__, json_encode($log));
  290. }else{
  291. return view("personnel/checking-in/enterGroupClock", compact('userWorkgroupID'));
  292. }
  293. }
  294. public function updateLaborReport($user_id,$userWorkgroupID,$userLaborToken=null)
  295. {
  296. $userDetail = UserDetail::find($user_id);
  297. $group_name = UserWorkgroup::where('id', $userWorkgroupID)->value('name');
  298. $laravelEchoPrefix = config('database.redis.options.prefix');
  299. $laborReportService = app('LaborReportService');
  300. //判断是否是第一次进组
  301. $laborReport = LaborReport::where('user_id', $user_id)->where('user_workgroup_id', null)->where('created_at', 'like', Carbon::now()->format('Y-m-d') . '%')->orderBy('id', 'desc')->first();
  302. if ($laborReport) {
  303. $newLaborReport = $laborReportService->enterGroupAndUpdateLaborReport($laborReport, $userWorkgroupID);
  304. $this->log(__METHOD__, "当日首次进组更新临时工报表记录__" . __FUNCTION__, json_encode($userWorkgroupID));
  305. if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  306. if ($newLaborReport) event(new ClockinEvent($newLaborReport));
  307. } else {
  308. //换组判断上一条临时工报表信息是否退组
  309. $laborReportNow = LaborReport::where('user_id', $user_id)->orderBy('id', 'desc')->first();
  310. if ($laborReportNow['group_user_id'] && !$laborReportNow['check_out_at']) return "<h1 style='color: darkred;text-align:center'>您还未退组,暂不可换组,请联系之前组长!</h1>";
  311. if (!$laborReportNow['group_user_id'] && $laborReportNow['user_workgroup_id']==$userWorkgroupID) return "<h1 style='color: darkred;text-align:center'>当前已进组,请等待组长审核!</h1>";
  312. //此处表示临时工换组操作
  313. $newLaborReport = $laborReportService->changeGroupAndMakeLaborReport($user_id, $userWorkgroupID);
  314. $this->log(__METHOD__, "当日临时工换组新建临时工报表记录__" . __FUNCTION__, json_encode([$user_id, $userWorkgroupID]));
  315. if (!$newLaborReport) return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
  316. if ($newLaborReport) event(new ClockinEvent($newLaborReport));
  317. }
  318. if ($userLaborToken){
  319. return response()->view('personnel/checking-in/success', ['group_name' => $group_name ?? '', 'full_name' => $userDetail->full_name, 'check_in_at' => $newLaborReport->check_in_at, 'laravelEchoPrefix' => $laravelEchoPrefix])
  320. ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
  321. }else{
  322. return response()->view('personnel/checking-in/success', ['group_name' => $group_name ?? '', 'full_name' => $userDetail->full_name, 'check_in_at' => $newLaborReport->check_in_at, 'laravelEchoPrefix' => $laravelEchoPrefix]);
  323. }
  324. }
  325. public function 绑定临时工并进组(Request $request){
  326. $userWorkgroupID = $request->input('userWorkgroupID');
  327. $mobile_phone = $request->input('mobile_phone');
  328. $userDetail = UserDetail::where('mobile_phone', $mobile_phone)->first();
  329. $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
  330. $dateNow = Carbon::now()->format('Y-m-d');
  331. $userDutyCheck = UserDutyCheck::where('user_id', $userDetail->user_id)->where('checked_at', 'like', $dateNow. '%')->orderBy('id', 'desc')->first();
  332. if (!$userDutyCheck['verify_user_id']) return "<h1 style='color: red;text-align:center'>进场门卫还未审核,暂无法进组!</h1>";
  333. if ($userDutyCheck->type == '登出') return "<h1 style='color: red;text-align:center'>进场是否未打卡?如若未打,请先返回打进场卡!</h1>";
  334. $this->log(__METHOD__, "进组扫码未绑定设备重新绑定__" . __FUNCTION__, json_encode([$userWorkgroupID,$userDetail]));
  335. $html=$this->updateLaborReport($userDetail->user_id,$userWorkgroupID,$userLaborToken);
  336. if ($html)return $html;
  337. }
  338. }