|
|
@@ -2,83 +2,66 @@
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
+use App\LaborCompany;
|
|
|
+use App\LaborReport;
|
|
|
use App\User;
|
|
|
use App\UserDetail;
|
|
|
use App\UserDutyCheck;
|
|
|
use App\UserLabor;
|
|
|
use App\UserToken;
|
|
|
use App\UserWorkgroup;
|
|
|
+use App\Warehouse;
|
|
|
use Carbon\Carbon;
|
|
|
use Endroid\QrCode\QrCode;
|
|
|
use Illuminate\Http\Request;
|
|
|
use Illuminate\Http\Response;
|
|
|
+use Illuminate\Support\Facades\Auth;
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
+use Illuminate\Support\Facades\Date;
|
|
|
use Illuminate\Support\Facades\Validator;
|
|
|
use Ramsey\Uuid\Uuid;
|
|
|
|
|
|
class UserDutyCheckController extends Controller
|
|
|
{
|
|
|
- public function goGetQRCode(){
|
|
|
- $userWorkgroups=UserWorkgroup::get();
|
|
|
- return view("personnel/checking-in/getQRcode",compact('userWorkgroups'));
|
|
|
- }
|
|
|
-
|
|
|
- //获取二维码
|
|
|
- public function getQRCode(Request $request){
|
|
|
- $userWorkgroup_id=$request->input('userWorkgroup_id');
|
|
|
- $qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
|
|
|
- if ($qrCode_refresh_everyday){
|
|
|
- $date=md5(date('Y-m-d'));
|
|
|
- $url=url("personnel/checking-in/userDutyCheck/clock?key=").$date;
|
|
|
- if ($userWorkgroup_id)$url=$url."&&userWorkgroupID=".$userWorkgroup_id;
|
|
|
- }else{
|
|
|
- $url=url("personnel/checking-in/userDutyCheck/clock");
|
|
|
- if ($userWorkgroup_id)$url=$url."?userWorkgroupID=".$userWorkgroup_id;
|
|
|
- }
|
|
|
- $qrCode=new QrCode($url);
|
|
|
- if ($userWorkgroup_id){
|
|
|
- $fileURL=base_path('public/images/QRCodeIMG/'.$userWorkgroup_id.'.png');
|
|
|
- if (file_exists($fileURL)){
|
|
|
- return url('images/QRCodeIMG/'.$userWorkgroup_id.'.png');
|
|
|
- }
|
|
|
- $qrCode->writeFile($fileURL);
|
|
|
- return url('images/QRCodeIMG/'.$userWorkgroup_id.'.png');
|
|
|
- }
|
|
|
- return (new Response())->header('Content-Type',$qrCode->getContentType())->setContent($qrCode->writeString());
|
|
|
- }
|
|
|
- //进入二维码显示页面
|
|
|
- public function QRCode(Request $request){
|
|
|
- $userWorkgroupId=$request->input('userWorkgroupId');
|
|
|
- $userWorkgroup=UserWorkgroup::find($userWorkgroupId);
|
|
|
- if (!$userWorkgroup)return view('exception.404',['error'=>'未找到工作组!']);
|
|
|
- return view('personnel/checking-in/QRcode',compact('userWorkgroup'));
|
|
|
- }
|
|
|
//校验二维码进入打卡页面
|
|
|
public function clock(Request $request){
|
|
|
$userWorkgroupID=$request->input('userWorkgroupID');
|
|
|
$qrCode_refresh_everyday=config('hr.qrCode_refresh_everyday');
|
|
|
+ $qrCode_refresh=config('hr.qrCode_refresh');
|
|
|
if ($qrCode_refresh_everyday){
|
|
|
$key=$request->input('key');
|
|
|
- if (!$key) return "二维码失效!";
|
|
|
+ if (!$key) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
$date=md5(date('Y-m-d'));
|
|
|
- if ($key!=$date) return "二维码失效!";
|
|
|
+ if ($key!=$date) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
+ }
|
|
|
+ if ($qrCode_refresh){
|
|
|
+ $key=$request->input('key');
|
|
|
+ if (!$key) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
+ $date=date('Y-m-d H:i:s');
|
|
|
+ if ($key<$date) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
}
|
|
|
$userLaborToken=$request->cookie('userLaborToken');
|
|
|
if ($userLaborToken && Cache::has('tokenStr_'.$userLaborToken)) {
|
|
|
$user_id=Cache::get('tokenStr_'.$userLaborToken);
|
|
|
$userDetail=UserDetail::find($user_id);
|
|
|
if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
|
|
|
- if ($userWorkgroupID){
|
|
|
- $user=UserToken::getUser($userLaborToken);
|
|
|
- $user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
+ $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
+ //正常情况
|
|
|
+ $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',Carbon::now()->format('Y-m-d')."%")->where('user_id',$userDetail->user_id)->first();
|
|
|
+ if(!isset($laborReport)&&$userDutyCheck->type=='登入'){
|
|
|
+ LaborReport::createLaborReportData($userDetail->user_id,$userWorkgroupID,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"提交临时工报表记录__".__FUNCTION__,json_encode($laborReport));
|
|
|
+ }else if ($laborReport&&$userDutyCheck->type=='登出'){
|
|
|
+ LaborReport::updateLaborReportData($laborReport,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"更新临时工报表记录__".__FUNCTION__,json_encode($laborReport));
|
|
|
}
|
|
|
- $userDutyCheck=$this->dutyCheck($userDetail->user_id);
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
$userWorkgroups=$userDetail->user->userWorkgroups();
|
|
|
if($userWorkgroups->count()>0)
|
|
|
$group_name=$userDetail->user->userWorkgroups->first()['name'];
|
|
|
- return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at]);
|
|
|
+ $laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
+ 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]);
|
|
|
}
|
|
|
return view("personnel/checking-in/clock",compact('userWorkgroupID'));
|
|
|
}
|
|
|
@@ -92,76 +75,146 @@ class UserDutyCheckController extends Controller
|
|
|
if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
|
|
|
$user=User::find($userDetail->user_id);
|
|
|
if (Cache::has('tokenUser_'.$user->id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
|
|
|
- if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
- $userDutyCheck=$this->dutyCheck($userDetail->user_id);
|
|
|
+ //if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
+ $userDutyCheckOld=UserDutyCheck::where('user_id',$userDetail->user_id)->orderBy('checked_at','DESC')->limit(10)->first();
|
|
|
+ $date=date('Y-m-d H:i:s');
|
|
|
+ $lastDate=Carbon::parse($userDutyCheckOld['checked_at']);
|
|
|
+ $thisDate=Carbon::parse($date);
|
|
|
+ $diffDate=$thisDate->diffInMinutes($lastDate);
|
|
|
+ $dateNow=Carbon::now()->format('Y-m-d');
|
|
|
+ //七天未登录从新选择劳务所
|
|
|
+ if ($diffDate>7*1440){
|
|
|
+ return redirect('personnel/checking-in/userDutyCheck/updateUserDetail/'.$mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
|
|
|
+ }
|
|
|
+ $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
+ //正常情况
|
|
|
+ $laborReport=LaborReport::where('user_workgroup_id',$userWorkgroupID)->where('created_at','like',$dateNow."%")->where('user_id',$userDetail->user_id)->first();
|
|
|
+ if(!$laborReport&&$userDutyCheck->type=='登入'){
|
|
|
+ LaborReport::createLaborReportData($userDetail->user_id,$userWorkgroupID,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"提交临时工报表记录__".__FUNCTION__,json_encode([$userDetail->user_id,$userWorkgroupID,$userDutyCheck]));
|
|
|
+ }else if ($laborReport&&$userDutyCheck->type=='登出'){
|
|
|
+ LaborReport::updateLaborReportData($laborReport,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"更新临时工报表记录__".__FUNCTION__,json_encode([$laborReport,$userDutyCheck]));
|
|
|
+ }
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
$userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
|
|
|
$group_name=$userDetail->user->userWorkgroups->first()['name'];
|
|
|
- return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at])
|
|
|
+ $laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
+ 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])
|
|
|
->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
|
|
|
}
|
|
|
//去往登记资料页面
|
|
|
public function createUserDetail($mobile_phone){
|
|
|
$userWorkgroupID=session("userWorkgroupID");
|
|
|
- return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID]);
|
|
|
+ $laborCompanies=LaborCompany::select('id','name')->get();
|
|
|
+ return view('personnel/checking-in/createUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
|
|
|
+ }
|
|
|
+ //七天未打卡去往选择劳务所页面
|
|
|
+ public function updateUserDetail($mobile_phone){
|
|
|
+ $userWorkgroupID=session("userWorkgroupID");
|
|
|
+ $laborCompanies=LaborCompany::select('id','name')->get();
|
|
|
+ return view('personnel/checking-in/updateUserDetail',['mobile_phone'=>$mobile_phone,'userWorkgroupID'=>$userWorkgroupID,'laborCompanies'=>$laborCompanies]);
|
|
|
+ }
|
|
|
+ //提交修改资料
|
|
|
+ public function storeUpdateUserDetail(Request $request){
|
|
|
+ $this->validator($request)->validate();
|
|
|
+ $mobile_phone=$request->input('mobile_phone');
|
|
|
+ $userWorkgroupID=$request->input('userWorkgroupID');
|
|
|
+ $userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
|
|
|
+ if (!$userDetail)return view('exception.404',['error'=>'临时工信息不存在!']);
|
|
|
+ $labor_company_id=$request->input('labor_company_id');
|
|
|
+ $userLabor=UserLabor::where('user_id',$userDetail->user_id)->first();
|
|
|
+ $userLabor->update([
|
|
|
+ 'labor_company_id'=>$labor_company_id,
|
|
|
+ ]);
|
|
|
+ $this->log(__METHOD__,"更改临时工劳务所信息".__FUNCTION__,json_encode($userLabor),Auth::user()['id']);
|
|
|
+ $userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
+ //添加临时工报表数据
|
|
|
+ LaborReport::createLaborReportData($userDetail->user_id,$userWorkgroupID,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"提交临时工报表记录__".__FUNCTION__,json_encode([$userDetail->user_id,$userWorkgroupID,$userDutyCheck]));
|
|
|
+ if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
+ if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
+ $user=User::find($userDetail->user_id);
|
|
|
+ $userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
|
|
|
+ $this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
|
|
|
+ $group_name=$userDetail->user->userWorkgroups->first()['name'];
|
|
|
+ $laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
+ 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])
|
|
|
+ ->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
|
|
|
}
|
|
|
-
|
|
|
//提交登记资料
|
|
|
public function storeUserDetail(Request $request){
|
|
|
$this->validator($request)->validate();
|
|
|
$mobile_phone=$request->input('mobile_phone');
|
|
|
$full_name=$request->input('full_name');
|
|
|
+ $identity_number=$request->input('identity_number');
|
|
|
$userWorkgroupID=$request->input('userWorkgroupID');
|
|
|
$user=new User([
|
|
|
'name'=>$mobile_phone,
|
|
|
'password'=>Uuid::uuid1(),
|
|
|
]);
|
|
|
$user->save();
|
|
|
- if ($userWorkgroupID)$user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
$userDetail=new UserDetail([
|
|
|
'user_id'=>$user->id,
|
|
|
'full_name'=>$full_name,
|
|
|
+ 'identity_number'=>$identity_number,
|
|
|
'gender'=>$request->input('gender'),
|
|
|
'mobile_phone'=>$mobile_phone,
|
|
|
'type'=>'临时工',
|
|
|
]);
|
|
|
$userDetail->save();
|
|
|
+ $labor_company_id=$request->input('labor_company_id');
|
|
|
$userLabor=new UserLabor([
|
|
|
'user_id'=>$user->id,
|
|
|
- 'company'=>$request->input('company'),
|
|
|
+ 'labor_company_id'=>$labor_company_id,
|
|
|
]);
|
|
|
$userLabor->save();
|
|
|
- $userDutyCheck=$this->dutyCheck($user->id);
|
|
|
+ $userDutyCheck=$this->dutyCheck($user->id,$userWorkgroupID);
|
|
|
+ LaborReport::createLaborReportData($user->id,$userWorkgroupID,$userDutyCheck);
|
|
|
+ $this->log(__METHOD__,"提交临时工报表记录__".__FUNCTION__,json_encode([$user->id,$userWorkgroupID,$userDutyCheck]));
|
|
|
if ($userDutyCheck&&$userDutyCheck->error)return "<h1 style='color: darkred;text-align:center'>重复打卡!</h1>";
|
|
|
if (!$userDutyCheck)return "<h1 style='color: red;text-align:center'>打卡异常,请联系相关人员!</h1>";
|
|
|
$userLaborToken=$user->token(config('users.token_check_in_expire_minutes'));
|
|
|
$this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
|
|
|
$group_name=$userDetail->user->userWorkgroups->first()['name'];
|
|
|
- return response()->view('personnel/checking-in/success',['group_name'=>$group_name??'','full_name'=>$userDetail->full_name,'checked_at'=>$userDutyCheck->checked_at])
|
|
|
+ $laravelEchoPrefix = config('database.redis.options.prefix');
|
|
|
+ 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])
|
|
|
->cookie('userLaborToken',$userLaborToken,config('users.token_check_in_expire_minutes'),'/');
|
|
|
}
|
|
|
|
|
|
//根据用户提交打卡记录
|
|
|
- public function dutyCheck($user_id){
|
|
|
+ public function dutyCheck($user_id,$userWorkgroupID){
|
|
|
$userDutyCheckOld=UserDutyCheck::where('user_id',$user_id)->orderBy('checked_at','DESC')->limit(10)->first();
|
|
|
+ if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']){
|
|
|
+ $user=User::find($user_id);
|
|
|
+ $user->userWorkgroups()->sync([$userWorkgroupID]);
|
|
|
+ }
|
|
|
$date=date('Y-m-d H:i:s');
|
|
|
+ $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode([$user_id,$userWorkgroupID,$date]));
|
|
|
$userDutyCheck=new UserDutyCheck([
|
|
|
'user_id'=>$user_id,
|
|
|
'checked_at'=>$date,
|
|
|
'source'=>'正常',
|
|
|
+ 'verify_user_id'=>'',
|
|
|
+ 'workgroup_id'=>$userWorkgroupID,
|
|
|
]);
|
|
|
if (!$userDutyCheckOld){
|
|
|
$userDutyCheck->type="登入";
|
|
|
$userDutyCheck->save();
|
|
|
- $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode($userDutyCheck));
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
$lastDate=Carbon::parse($userDutyCheckOld->checked_at);
|
|
|
$thisDate=Carbon::parse($date);
|
|
|
$diffDate=$thisDate->diffInMinutes($lastDate);
|
|
|
+ if ($userDutyCheckOld->type=="登出"&&$diffDate<7*1440){
|
|
|
+ $userDutyCheck->type="登入";
|
|
|
+ $userDutyCheck->verify_user_id=0;
|
|
|
+ $userDutyCheck->save();
|
|
|
+ return $userDutyCheck;
|
|
|
+ }
|
|
|
if($diffDate<=5){
|
|
|
- $userDutyCheck->error=true;
|
|
|
+ $userDutyCheck->error=true;//重复打卡
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
if ($userDutyCheckOld->type=="登入"){
|
|
|
@@ -186,16 +239,28 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
}
|
|
|
$userDutyCheck->save();
|
|
|
- $this->log(__METHOD__,"提交打卡记录__".__FUNCTION__,json_encode($userDutyCheck));
|
|
|
return $userDutyCheck;
|
|
|
}
|
|
|
-
|
|
|
public function validator(Request $request){
|
|
|
$validator=Validator::make($request->input(),[
|
|
|
'full_name'=>['filled'],
|
|
|
+ 'userWorkgroupID'=>['filled'],
|
|
|
'gender'=>['filled'],
|
|
|
'mobile_phone'=>['required','integer','digits:11'],
|
|
|
- ],[],[]);
|
|
|
+ 'identity_number' => ['filled','identity_cards','unique:user_details,identity_number'],
|
|
|
+ ],[
|
|
|
+ 'unique'=>':attribute 已经存在,不能重复!',
|
|
|
+ 'filled' => ':attribute 不能为空',
|
|
|
+ 'required'=>':attribute 为必填项',
|
|
|
+ 'integer'=>':attribute 数字类型',
|
|
|
+ 'digits'=>':attribute 必须是11位',
|
|
|
+ ],[
|
|
|
+ 'full_name'=>'姓名',
|
|
|
+ 'userWorkgroupID'=>'工作组ID',
|
|
|
+ 'gender'=>'性别',
|
|
|
+ 'mobile_phone'=>'手机号',
|
|
|
+ 'identity_number' => '身份证号',
|
|
|
+ ]);
|
|
|
return $validator;
|
|
|
}
|
|
|
}
|