MasterWorkerLogic.php 14 KB

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