MasterWorkerLogic.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. <?php
  2. namespace app\workerapi\logic;
  3. use think\Exception;
  4. use think\facade\Db;
  5. use think\facade\Config;
  6. use app\common\enum\YesNoEnum;
  7. use app\common\logic\BaseLogic;
  8. use app\common\service\FileService;
  9. use app\common\model\works\ServiceWork;
  10. use app\common\model\bank_account\BankAccount;
  11. use app\common\enum\worker\WorkerAccountLogEnum;
  12. use app\common\model\master_worker\MasterWorker;
  13. use app\common\model\master_worker\MasterWorkerInfo;
  14. use app\common\model\master_worker\MasterWorkerAgree;
  15. use app\common\model\master_worker\MasterWorkerQuestion;
  16. use app\common\model\master_worker\MasterWorkerInterview;
  17. use app\common\model\master_worker\MasterWorkerAccountLog;
  18. use app\common\model\master_worker_register\MasterWorkerRegister;
  19. /**
  20. * @author 林海涛
  21. * @date 2024/7/10 下午1:45
  22. */
  23. class MasterWorkerLogic extends BaseLogic
  24. {
  25. public static function changePassword(array $params, int $userId)
  26. {
  27. try {
  28. $user = MasterWorker::findOrEmpty($userId);
  29. if ($user->isEmpty()) {
  30. throw new \Exception('用户不存在');
  31. }
  32. // 密码盐
  33. $passwordSalt = Config::get('project.unique_identification');
  34. /*if (!empty($user['password'])) {
  35. if (empty($params['old_password'])) {
  36. throw new \Exception('请填写旧密码');
  37. }
  38. $oldPassword = create_password($params['old_password'], $passwordSalt);
  39. if ($oldPassword != $user['password']) {
  40. throw new \Exception('原密码不正确');
  41. }
  42. }*/
  43. // 保存密码
  44. $password = create_password($params['password'], $passwordSalt);
  45. $user->password = $password;
  46. $user->save();
  47. return true;
  48. } catch (\Exception $e) {
  49. self::setError($e->getMessage());
  50. return false;
  51. }
  52. }
  53. public static function changeMobile(array $params, int $userId)
  54. {
  55. try {
  56. $user = MasterWorker::findOrEmpty($userId);
  57. if ($user->isEmpty()) {
  58. throw new \Exception('用户不存在');
  59. }
  60. if($user->mobile == $params['mobile']){
  61. throw new \Exception('输入的手机号相同');
  62. }
  63. $where = [['mobile', '=', $params['mobile']]];
  64. $existUser = MasterWorker::where($where)->findOrEmpty();
  65. if (!$existUser->isEmpty()) {
  66. throw new \Exception('该手机号已被使用');
  67. }
  68. $user->mobile= $params['mobile'];
  69. $user->save();
  70. return true;
  71. } catch (\Exception $e) {
  72. self::setError($e->getMessage());
  73. return false;
  74. }
  75. }
  76. public static function logOff(int $userId)
  77. {
  78. try {
  79. $user = MasterWorker::findOrEmpty($userId);
  80. if ($user->isEmpty()) {
  81. throw new \Exception('用户不存在');
  82. }
  83. if($user->work_status == 0 ){
  84. throw new Exception('请先申请长期停单');
  85. }
  86. if($user->work_status == 1 ){
  87. throw new Exception('请等待长期停单审核');
  88. }
  89. $user->is_disable = YesNoEnum::YES;
  90. $user->save();
  91. return true;
  92. } catch (\Exception $e) {
  93. self::setError($e->getMessage());
  94. return false;
  95. }
  96. }
  97. public static function stopWork(int $userId)
  98. {
  99. try {
  100. $user = MasterWorker::findOrEmpty($userId);
  101. if ($user->isEmpty()) {
  102. throw new \Exception('用户不存在');
  103. }
  104. if($user->work_status == 1 ){
  105. throw new Exception('请等待长期停单审核');
  106. }
  107. if($user->work_status == 2 ){
  108. throw new Exception('长期停单审核通过');
  109. }
  110. $user->work_status = 1;
  111. $user->accept_order_status = 0;
  112. $user->save();
  113. return true;
  114. } catch (\Exception $e) {
  115. self::setError($e->getMessage());
  116. return false;
  117. }
  118. }
  119. public static function detail($userId): array
  120. {
  121. $worker = MasterWorker::field('id,team_id,team_role,sn,avatar,real_avatar,real_name,nickname,account,mobile,sex,estimate_money,user_money,earnest_money,exp,worker_number,work_status,accept_order_status')
  122. ->findOrEmpty($userId)
  123. ->toArray();
  124. //验证是否上传身份证
  125. $is_id_card = MasterWorkerInfo::where('worker_id',$userId)->whereIn('audit_state','0,1')->findOrEmpty()->toArray();
  126. //判断是否填写银行信息
  127. $is_bank = BankAccount::where('worker_id',$userId)->whereIn('audit_state','0,1')->findOrEmpty()->toArray();
  128. //监测是否签署服务合作协议
  129. $pdf = MasterWorkerAgree::where(['agree_type'=>'master_service_content','worker_id'=>$userId])->whereIn('audit_state','0,1')->value('pdf_url');
  130. $worker['is_id_card'] = !empty($is_id_card)?1:0;
  131. $worker['is_bank'] = !empty($is_bank)?1:0;
  132. $worker['is_service_agree'] = !empty($pdf)?1:0;
  133. //今日退款
  134. $worker['refund_account_today'] = MasterWorkerAccountLog::where(['worker_id'=> $worker['id'],'action'=>2,'change_type'=>WorkerAccountLogEnum::UM_DEC_ADMIN])->whereTime('create_time', 'today')->sum('change_amount');
  135. //今日收益
  136. $worker['account_today'] = MasterWorkerAccountLog::where(['worker_id'=> $worker['id'],'action'=>1,'change_type'=>WorkerAccountLogEnum::UM_INC_ADMIN])->whereTime('create_time', 'today')->sum('change_amount')-$worker['refund_account_today'];
  137. //本月成功订单
  138. $worker['success_work'] = ServiceWork::where(['master_worker_id'=>$worker['id'],'service_status'=>3])->whereTime('create_time', 'month')->count();
  139. //本月失败单
  140. $worker['fail_work'] = ServiceWork::where(['master_worker_id'=>$worker['id']])->whereIn('service_status','4,5')->whereTime('create_time', 'month')->count();
  141. return $worker;
  142. }
  143. public static function setInfo(int $userId, array $params)
  144. {
  145. try {
  146. if ($params['field'] == "avatar" || $params['field'] == "real_avatar") {
  147. $params['value'] = FileService::setFileUrl($params['value']);
  148. }
  149. $upData = [
  150. 'id' => $userId,
  151. $params['field'] => $params['value']
  152. ];
  153. if($params['field'] == 'accept_order_status'){
  154. $masterWorker = MasterWorker::where(['id'=>$userId])->findOrEmpty();
  155. if($masterWorker['work_status'] != 0 || $masterWorker['is_disable'] != 0){
  156. throw new Exception('该账号已禁用或已长期停单');
  157. }
  158. $accept_status_time = $masterWorker['accept_status_time'];
  159. if($masterWorker['accept_order_status'] ==1 && $params['value'] == 0 && $accept_status_time > 0){
  160. if(time() < ($accept_status_time+2*3600)){
  161. throw new Exception('开启接单后两小时后才能关闭接单');
  162. }
  163. }
  164. $upData['accept_status_time'] = time();
  165. //验证身份证信息是否审核通过
  166. $idCard = MasterWorkerInfo::where(['worker_id'=>$userId])->findOrEmpty();
  167. if ($idCard->isEmpty()) {
  168. return ['code'=>20,'msg'=>'请先完善身份证信息'];
  169. }
  170. if($idCard->audit_state == 0){
  171. return ['code'=>20,'msg'=>'身份证信息核验中,请等待核验完成'];
  172. }
  173. if($idCard->audit_state == 2){
  174. return ['code'=>20,'msg'=>'身份证信息核验不通过,请重新填写'];
  175. }
  176. //验证银行卡信息是否审核通过
  177. $bank = BankAccount::where(['worker_id'=>$userId])->findOrEmpty();
  178. if ($bank->isEmpty()) {
  179. return ['code'=>21,'msg'=>'请先完善银行卡信息'];
  180. }
  181. if($bank->audit_state == 0){
  182. return ['code'=>21,'msg'=>'银行卡信息核验中,请等待核验完成'];
  183. }
  184. if($bank->audit_state == 2){
  185. return ['code'=>21,'msg'=>'银行卡信息核验不通过,请重新填写'];
  186. }
  187. //验证协议信息是否审核通过
  188. $agree = MasterWorkerAgree::where(['worker_id'=>$userId])->findOrEmpty();
  189. if ($agree->isEmpty()) {
  190. return ['code'=>22,'msg'=>'请先签写协议信息'];
  191. }
  192. if($agree->audit_state == 0){
  193. return ['code'=>22,'msg'=>'协议信息核验中,请等待核验完成'];
  194. }
  195. if($agree->audit_state == 2){
  196. return ['code'=>22,'msg'=>'协议信息核验不通过,请重新签写'];
  197. }
  198. }
  199. MasterWorker::update($upData);
  200. return [];
  201. } catch (\Exception $e) {
  202. self::$error = $e->getMessage();
  203. self::$returnCode = $e->getCode();
  204. return false;
  205. }
  206. }
  207. /**
  208. * 查询机器人面试结果
  209. */
  210. public static function getInterview(array $params)
  211. {
  212. if (empty($params['worker_id'])) {
  213. return false;
  214. }
  215. $info = MasterWorkerInterview::where('worker_id',$params['worker_id'])
  216. ->field('id,worker_id,type,status,nickname,create_time')
  217. ->select()
  218. ->toArray();
  219. return $info;
  220. }
  221. /**
  222. * 机器人面试结果
  223. */
  224. public static function setInterview(array $params)
  225. {
  226. try {
  227. if (empty($params['worker_id']) || empty($params['answer']) || empty($params['answer1']) || empty($params['answer2']) ) {
  228. return false;
  229. }
  230. if (!empty($params['answer7'])) {
  231. //维修
  232. $type = 1;
  233. } else if (!empty($params['answer6'])) {
  234. //清洗
  235. $type = 2;
  236. } else if (!empty($params['answer5'])) {
  237. //安装
  238. $type = 3;
  239. $params['status'] = 1;
  240. } else {
  241. $type = 0;
  242. $params['status'] = 0;
  243. }
  244. //校验一下工程师注册ID是否有效
  245. $worker_register_id = $params['worker_id'];
  246. $worker_register_id = MasterWorkerRegister::where('id',$worker_register_id)->value('id');
  247. if (!$worker_register_id) {
  248. return false;
  249. }
  250. $info = MasterWorkerInterview::where('worker_id',$params['worker_id'])->value("id");
  251. if ($info) {
  252. return false;
  253. }
  254. $params['nickname'] = isset($params['nickname']) ?? '';
  255. $insertData = [
  256. 'sys_uuid' => $params['sys_uuid'],
  257. 'worker_id' => $params['worker_id'],
  258. 'nickname' => $params['nickname'],
  259. 'type' => $type,
  260. 'status' => $params['status'],
  261. ];
  262. unset($params['sys_uuid']);
  263. unset($params['worker_id']);
  264. unset($params['nickname']);
  265. unset($params['status']);
  266. $insertData['content'] = json_encode($params);
  267. Db::startTrans();
  268. MasterWorkerInterview::create($insertData);
  269. MasterWorkerRegisterLogic::createMasterWorker(['worker_register_id' => $worker_register_id]);
  270. Db::commit();
  271. return [];
  272. } catch (\Exception $e) {
  273. Db::rollback();
  274. self::$error = $e->getMessage();
  275. self::$returnCode = $e->getCode();
  276. return false;
  277. }
  278. }
  279. /**
  280. * 查询工程师面试题库
  281. */
  282. public static function getQuestion(array $params)
  283. {
  284. if ($params['type'] == 1 || $params['type'] == 2) {
  285. $category = trim($params['category']);
  286. $category = str_replace(',', ',', $category);
  287. $category = explode(',', $category);
  288. $category = array_slice($category, 0, 5);
  289. $list = MasterWorkerQuestion::where('type',$params['type'])
  290. ->whereIn('category', $category)
  291. ->where('type',$params['type'])
  292. ->limit(100)
  293. ->select()
  294. ->toArray();
  295. // 按 category 分组
  296. $grouped = [];
  297. foreach ($list as $item) {
  298. $category = $item['category'];
  299. if (!isset($grouped[$category])) {
  300. $grouped[$category] = [];
  301. }
  302. $grouped[$category][] = $item;
  303. }
  304. // 从每组中随机取 5 个元素
  305. $result = [];
  306. foreach ($grouped as $category => $items) {
  307. $randomItems = [];
  308. $count = count($items);
  309. if ($count <= 5) {
  310. $randomItems = $items;
  311. } else {
  312. $keys = array_rand($items, 5);
  313. foreach ($keys as $key) {
  314. $randomItems[] = $items[$key];
  315. }
  316. }
  317. $result = array_merge($result,$randomItems);
  318. }
  319. $text = '';
  320. $i = 0;
  321. foreach($result as $item) {
  322. $i++;
  323. $text .= $i.'.'.$item['title']."\r\n"." ". str_replace(",","\r\n",$item['options'])."\r\n\r\n";
  324. }
  325. return [
  326. 'list' => array_values($result),
  327. 'text' => $text
  328. ];
  329. }
  330. return false;
  331. }
  332. public static function getRegInfo(array $params)
  333. {
  334. if (empty($params['user'])){
  335. return 0;
  336. }
  337. $user = trim($params['user']);
  338. $pattern = '/(\d{11})/';
  339. if (preg_match($pattern, $user, $matches)) {
  340. // 提取手机号
  341. $mobile = $matches[1];
  342. }
  343. $specialChars = array('.', ',', '。', ',', $mobile);
  344. $name = str_replace($specialChars,"",$user);
  345. return (int)MasterWorkerRegister::where('name',$name)->where('mobile',$mobile)->value('id');
  346. }
  347. }