isEmpty()) { throw new \Exception('用户不存在'); } // 密码盐 $passwordSalt = Config::get('project.unique_identification'); if (!empty($user['password'])) { if (empty($params['old_password'])) { throw new \Exception('请填写旧密码'); } $oldPassword = create_password($params['old_password'], $passwordSalt); if ($oldPassword != $user['password']) { throw new \Exception('原密码不正确'); } } // 保存密码 $password = create_password($params['password'], $passwordSalt); $user->password = $password; $user->save(); return true; } catch (\Exception $e) { self::setError($e->getMessage()); return false; } } public static function changeMobile(array $params, int $userId) { try { $user = MasterWorker::findOrEmpty($userId); if ($user->isEmpty()) { throw new \Exception('用户不存在'); } if($user->mobile == $params['mobile']){ throw new \Exception('输入的手机号相同'); } $where = [['mobile', '=', $params['mobile']]]; $existUser = MasterWorker::where($where)->findOrEmpty(); if (!$existUser->isEmpty()) { throw new \Exception('该手机号已被使用'); } $user->mobile= $params['mobile']; $user->save(); return true; } catch (\Exception $e) { self::setError($e->getMessage()); return false; } } public static function logOff(int $userId) { try { $user = MasterWorker::findOrEmpty($userId); if ($user->isEmpty()) { throw new \Exception('用户不存在'); } $user->is_disable = YesNoEnum::YES; $user->save(); return true; } catch (\Exception $e) { self::setError($e->getMessage()); return false; } } public static function detail($userId): array { $worker = MasterWorker::field('id,sn,avatar,real_avatar,real_name,nickname,account,mobile,sex,estimate_money,user_money,earnest_money,exp') ->findOrEmpty($userId) ->toArray(); //今日收益 $worker['account_today'] = MasterWorkerAccountLog::where(['worker_id'=> $worker['id'],'action'=>1])->whereTime('create_time', 'today')->sum('change_amount'); //本月成功订单 $worker['success_work'] = ServiceWork::where(['master_worker_id'=>$worker['id'],'service_status'=>3])->whereTime('create_time', 'month')->count(); //本月失败单 $worker['fail_work'] = ServiceWork::where(['master_worker_id'=>$worker['id'],'service_status'=>4])->whereTime('create_time', 'month')->count(); return $worker; } }