|
|
@@ -37,8 +37,8 @@ class UserDutyCheckController extends Controller
|
|
|
if ($key<$date) return view('exception.404',['error'=>'二维码失效!']);
|
|
|
}
|
|
|
$userLaborToken=$request->cookie('userLaborToken');
|
|
|
- if ($userLaborToken && Cache::has('tokenStr_'.$userLaborToken)) {
|
|
|
- $user_id=Cache::get('tokenStr_'.$userLaborToken);
|
|
|
+ if ($userLaborToken && Cache::has('dutyCheckTokenStr_'.$userLaborToken)) {
|
|
|
+ $user_id=Cache::get('dutyCheckTokenStr_'.$userLaborToken);
|
|
|
$userDetail=UserDetail::find($user_id);
|
|
|
if (!$userDetail) return redirect('personnel/checking-in/userDutyCheck/createUserDetail/'.$userDetail->mobile_phone)->with("userWorkgroupID",$userWorkgroupID);
|
|
|
$userDutyCheck=$this->dutyCheck($userDetail->user_id,$userWorkgroupID);
|
|
|
@@ -55,9 +55,7 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
if ($userDutyCheck&&$userDutyCheck->error==true)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'];
|
|
|
+ $group_name=$userDutyCheck->userWorkgroup['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]);
|
|
|
}
|
|
|
@@ -71,9 +69,7 @@ class UserDutyCheckController extends Controller
|
|
|
$this->validator($request)->validate();
|
|
|
$userDetail=UserDetail::where('mobile_phone',$mobile_phone)->first();
|
|
|
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]);
|
|
|
+ if (Cache::has('dutyCheckTokenUser_'.$userDetail->user_id))return "<h1 style='color: red;text-align:center'>请使用原有设备进行打卡,如无法使用原有设备请联系管理人员解绑设备!</h1>";
|
|
|
$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']);
|
|
|
@@ -98,8 +94,8 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
if ($userDutyCheck&&$userDutyCheck->error==true)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'];
|
|
|
+ $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
|
|
|
+ $group_name=$userDutyCheck->userWorkgroup['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'),'/');
|
|
|
@@ -137,10 +133,9 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
if ($userDutyCheck&&$userDutyCheck->error==true)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'));
|
|
|
+ $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
|
|
|
$this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
|
|
|
- $group_name=$userDetail->user->userWorkgroups->first()['name'];
|
|
|
+ $group_name=$userDutyCheck->userWorkgroup['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'),'/');
|
|
|
@@ -180,9 +175,9 @@ class UserDutyCheckController extends Controller
|
|
|
}
|
|
|
if ($userDutyCheck&&$userDutyCheck->error==true)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'));
|
|
|
+ $userLaborToken=$userDetail->getDutyCheckToken(config('users.token_check_in_expire_minutes'));
|
|
|
$this->log(__METHOD__,"录入临时工,用户,对应工作组,打卡记录".__FUNCTION__,json_encode($request->all()));
|
|
|
- $group_name=$userDutyCheck->userWorkgroup->first()['name'];
|
|
|
+ $group_name=$userDutyCheck->userWorkgroup['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'),'/');
|
|
|
@@ -237,9 +232,10 @@ class UserDutyCheckController extends Controller
|
|
|
switch ($diffDate){
|
|
|
case $diffDate<=20:
|
|
|
$userDutyCheck->type="登入";
|
|
|
+ $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
|
|
|
break;
|
|
|
case $diffDate>=1380:
|
|
|
- $userDutyCheck->type="登入";
|
|
|
+ $userDutyCheck->type=="登入";
|
|
|
break;
|
|
|
default:
|
|
|
$userDutyCheck->type="登出";
|
|
|
@@ -251,13 +247,19 @@ class UserDutyCheckController extends Controller
|
|
|
case $diffDate<=20:
|
|
|
$userDutyCheck->type="登出";
|
|
|
$userDutyCheck->verify_user_id=0;
|
|
|
+ $userDutyCheck->workgroup_id=$userDutyCheckOld->workgroup_id;
|
|
|
break;
|
|
|
default:
|
|
|
$userDutyCheck->type="登入";
|
|
|
}
|
|
|
}
|
|
|
if ($userWorkgroupID!=$userDutyCheckOld['workgroup_id']&&$userDutyCheckOld->type=="登入"&&$userDutyCheck->type="登出"){
|
|
|
- $userDutyCheck->workgroup_id=$userDutyCheckOld['workgroup_id'];
|
|
|
+ if ($diffDate>=1380){
|
|
|
+ $userDutyCheck->type="登入";
|
|
|
+ }else{
|
|
|
+ $userDutyCheck->workgroup_id=$userDutyCheckOld['workgroup_id'];
|
|
|
+ }
|
|
|
+
|
|
|
}
|
|
|
$userDutyCheck->save();
|
|
|
return $userDutyCheck;
|