My.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703
  1. <?php
  2. namespace app\mainapp\controller;
  3. use app\common\model\Feedback;
  4. use app\common\model\ResumeInvite;
  5. use app\common\model\UserGetmoneyLog as UserGetmoneyLogModel;
  6. use app\common\model\UserGetmoneyLog;
  7. use app\common\model\UserWill;
  8. use app\common\service\BalanceService;
  9. use app\common\service\IntegralService;
  10. use app\common\service\SmsService;
  11. use app\mainapp\BaseController;
  12. use app\common\model\Param as ParamModel;
  13. use app\common\model\User as UserModel;
  14. use app\common\model\UserAuths as UserAuthsModel;
  15. use app\common\model\UserGroups as UserGroupsModel;
  16. use app\common\model\UserIntegral as UserIntegralModel;
  17. use app\common\model\UserParam as UserParamModel;
  18. use app\common\model\UserPart as UserPartModel;
  19. use app\common\model\UserRank as UserRankModel;
  20. use app\common\model\ComjobsLog as ComjobsLogModel;
  21. use app\common\model\Resident as ResidentModel;
  22. use app\common\model\Worker as WorkerModel;
  23. use app\common\model\Agent as AgentModel;
  24. use app\common\model\Broker as BrokerModel;
  25. use app\common\model\ArticleCollect as ArticleCollectModel;
  26. use echowx\WxProgram;
  27. use echowx\WxPay;
  28. use payment\wechat\WechatTransfers;
  29. use think\facade\Log;
  30. class My extends BaseController
  31. {
  32. // 我的推广码
  33. public function pageCode()
  34. {
  35. $param = ParamModel::where(1)->find();
  36. $plist = UserRankModel::order('partnumber', 'desc')->limit(100)->select();
  37. page_result(0, "", [
  38. 'param' => $param,
  39. 'plist' => $plist,
  40. 'pcount' => count($plist),
  41. ]);
  42. }
  43. public function refCode()
  44. {
  45. $userid = input('userid/d', 0);
  46. $wxprogram = new WxProgram();
  47. $wxampcode = $wxprogram->wxacode_get_unlimited($userid, "pages/login/sharepuser", 430, "attachment/wxampcode/" . md5(time()) . ".jpg");
  48. if ($wxampcode == false) {
  49. page_result(1, "小程序码生成失败,请稍后再试。");
  50. }
  51. UserModel::update([
  52. 'id' => $userid,
  53. 'wxampcode' => $wxampcode,
  54. ]);
  55. page_result(0, "", [
  56. 'wxampcode' => $wxampcode,
  57. ]);
  58. }
  59. public function regUser()
  60. {
  61. $userid = input('userid/d', 0);
  62. $user = UserModel::findOrEmpty($userid);
  63. if ($user->isEmpty()) {
  64. page_result(1, "用户信息不存在");
  65. }
  66. $realname = input('realname/s', "");
  67. $mobile = input('mobile/s', "");
  68. if (empty($realname) || empty($mobile)) {
  69. page_result(1, "姓名手机号均不能为空。");
  70. }
  71. $reguser = WorkerModel::where('mobile', '=', $mobile)->findOrEmpty();
  72. if (!$reguser->isEmpty()) {
  73. page_result(1, "该手机号已注册过了。");
  74. }
  75. $groups = UserGroupsModel::order(['isdefault' => 'desc', 'id' => 'asc'])->findOrEmpty();
  76. $groupsid = $groups->isEmpty() ? 0 : $groups->id;
  77. $newuser = new UserModel;
  78. $newuser->save([
  79. 'groupsid' => $groupsid,
  80. 'brokerid' => $user->brokerid,
  81. 'nickname' => $realname,
  82. 'avatar' => "",
  83. 'realname' => $realname,
  84. 'mobile' => $mobile,
  85. 'password' => md5(time() . mt_rand(100000, 999999)),
  86. 'integral' => 0,
  87. 'inttotal' => 0,
  88. 'status' => 2,
  89. 'isvip' => 1,
  90. 'authstatus' => 1,
  91. 'authremark' => "",
  92. 'idcardzpic' => "",
  93. 'idcardfpic' => "",
  94. 'idcard' => "",
  95. 'gender' => 1,
  96. 'birthday' => "",
  97. 'address' => "",
  98. 'education' => "",
  99. 'createtime' => time(),
  100. 'jobintention' => "",
  101. 'workexperience' => "",
  102. 'eduexperience' => "",
  103. 'followstatus' => 1,
  104. 'wxampcode' => "",
  105. 'bankcard' => ['openbank' => "", 'account' => "", 'number' => ""],
  106. ]);
  107. $mobileuserauths = new UserAuthsModel;
  108. $mobileuserauths->save([
  109. 'userid' => $newuser->id,
  110. 'identitytype' => "mobile",
  111. 'identifier' => $mobile,
  112. 'password' => md5(time() . mt_rand(100000, 999999)),
  113. 'logintime' => time(),
  114. 'loginip' => $_SERVER['SERVER_ADDR'],
  115. ]);
  116. $param = UserParamModel::where(1)->findOrEmpty();
  117. $part = new UserPartModel;
  118. $part->save([
  119. 'puserid' => $userid,
  120. 'userid' => $newuser->id,
  121. 'redmoney' => intval($param->redmoney),
  122. 'status' => 1,
  123. 'createtime' => time(),
  124. ]);
  125. if ($param->postintegral > 0) {
  126. $integral = new UserIntegralModel;
  127. $integral->save([
  128. 'userid' => $user->id,
  129. 'title' => "推荐注册用户奖励",
  130. 'intvalue' => $param->postintegral,
  131. 'intmoney' => 0.00,
  132. 'onlycontent' => "",
  133. 'remark' => "推荐注册用户【" . $realname . "】奖励积分",
  134. 'itype' => 1,
  135. 'status' => 2,
  136. 'createtime' => time(),
  137. 'yeartime' => date("Y"),
  138. 'monthtime' => date("Ym"),
  139. ]);
  140. $updata = [
  141. 'integral' => $user->integral + $param->postintegral,
  142. 'inttotal' => $user->inttotal + $param->postintegral,
  143. ];
  144. $user->save($updata);
  145. }
  146. page_result(0, "", []);
  147. }
  148. // 获得用户信息
  149. public function getUser()
  150. {
  151. $param = ParamModel::where(1)->find();
  152. $userid = input('userid/d');
  153. $user = UserModel::findOrEmpty($userid);
  154. if ($user->isEmpty()) {
  155. page_result(1, "用户信息不存在");
  156. }
  157. // $user['nickname'] = mb_substr($user['nickname'],0,6,'utf-8').'...';
  158. $workerall = WorkerModel::where('userid', '=', $user->id)->select();
  159. $agentall = AgentModel::where('userid', '=', $user->id)->select();
  160. $brokerall = BrokerModel::where('userid', '=', $user->id)->select();
  161. $resident = ResidentModel::where('userid', '=', $user->id)->findOrEmpty();
  162. page_result(0, "", [
  163. 'param' => $param,
  164. 'user' => $user,
  165. 'workerall' => $workerall->isEmpty() ? null : $workerall,
  166. 'agentall' => $agentall->isEmpty() ? null : $agentall,
  167. 'brokerall' => $brokerall->isEmpty() ? null : $brokerall,
  168. 'resident' => empty($resident) ? null : $resident,
  169. ]);
  170. }
  171. // 我的经纪人
  172. public function getMyBroker()
  173. {
  174. $userid = input('userid/d');
  175. $user = UserModel::findOrEmpty($userid);
  176. if ($user->isEmpty()) {
  177. page_result(1, "用户信息不存在");
  178. }
  179. $agent = AgentModel::where('id', '=', $user->agentid)->find();
  180. $broker = BrokerModel::where('id', '=', $user->brokerid)->find();
  181. page_result(0, "", [
  182. 'agent' => $agent,
  183. 'broker' => $broker,
  184. ]);
  185. }
  186. // 收藏夹
  187. public function listCollect()
  188. {
  189. $ppage = input('ppage/d', 1);
  190. $psize = input('psize/d', 20);
  191. $userid = input('userid/d', 0);
  192. if (empty($userid)) {
  193. page_result(1, "用户信息不存在");
  194. }
  195. $plist = ArticleCollectModel::with('article')->where('userid', '=', $userid)->order(['id' => 'desc'])->page($ppage)->limit($psize)->select();
  196. page_result(0, "", [
  197. 'plist' => $plist,
  198. 'pstatus' => $psize > count($plist) ? 'noMore' : 'more',
  199. ]);
  200. }
  201. public function delCollect()
  202. {
  203. $id = input('id/d', 0);
  204. $userid = input('userid/d', 0);
  205. $collect = ArticleCollectModel::where(['id' => $id, 'userid' => $userid])->findOrEmpty();
  206. $result = $collect->delete();
  207. if ($result) {
  208. exit(json_encode([
  209. 'code' => 0,
  210. 'msg' => "",
  211. ]));
  212. }
  213. exit(json_encode([
  214. 'code' => 1,
  215. 'msg' => "删除失败,请稍后重试",
  216. ]));
  217. }
  218. // 我的邀请
  219. public function myTeam()
  220. {
  221. $userid = input('userid/d', 0);
  222. $user = UserModel::findOrEmpty($userid);
  223. if ($user->isEmpty()) {
  224. page_result(1, "用户信息不存在。");
  225. }
  226. $redmoneyarr = ['status0' => 0, 'status1' => 0, 'status2' => 0, 'status3' => 0];
  227. $redmoneyall = UserPartModel::field('status, userid, SUM(redmoney) AS redmoneysum')->where('puserid', '=', $userid)->group('status')->select()->toArray();
  228. if (!empty($redmoneyall)) {
  229. foreach ($redmoneyall as $k => $v) {
  230. $redmoneyarr['status' . $v['status']] = intval($v['redmoneysum']);
  231. }
  232. }
  233. $redmoneyarr['status0'] = $redmoneyarr['status2'] + $redmoneyarr['status3'];
  234. page_result(0, "", [
  235. 'redmoneyarr' => $redmoneyarr,
  236. ]);
  237. }
  238. public function getTeam()
  239. {
  240. $ppage = input('ppage/d', 1);
  241. $psize = input('psize/d', 20);
  242. $userid = input('userid/d', 0);
  243. if ($userid != 0) {
  244. $map[] = ['puserid', '=', $userid];
  245. }
  246. $status = input('status/d', 0);
  247. if ($status != 0) {
  248. $map[] = ['status', '=', $status];
  249. }
  250. $plist = UserPartModel::with('user')->where($map)->order(['id' => 'desc'])->page($ppage)->limit($psize)->select();
  251. page_result(0, "", [
  252. 'plist' => $plist,
  253. 'pstatus' => $psize > count($plist) ? 'noMore' : 'more',
  254. ]);
  255. }
  256. // 我的积分
  257. public function myIntegral()
  258. {
  259. $userid = input('userid/d', 0);
  260. $user = UserModel::findOrEmpty($userid);
  261. if ($user->isEmpty()) {
  262. page_result(1, "用户信息不存在。");
  263. }
  264. $monthtime = date('Ym', strtotime('-1 month'));
  265. $monthintegral = UserIntegralModel::where(['monthtime' => $monthtime, 'userid' => $userid])->sum('intvalue');
  266. $userparam = UserParamModel::where(1)->findOrEmpty();
  267. page_result(0, "", [
  268. 'user' => $user,
  269. 'monthintegral' => $monthintegral,
  270. 'userparam' => $userparam,
  271. ]);
  272. }
  273. public function getRecharge()
  274. {
  275. $userid = input('userid/d', 0);
  276. $user = UserModel::findOrEmpty($userid);
  277. if ($user->isEmpty()) {
  278. page_result(1, "用户信息不存在。");
  279. }
  280. $userauths = UserAuthsModel::where(['userid' => $userid, 'identitytype' => "weixin"])->findOrEmpty();
  281. if ($userauths->isEmpty()) {
  282. page_result(1, "请先授权微信号登录。");
  283. }
  284. $userparam = UserParamModel::where(1)->findOrEmpty();
  285. if ($userparam->isEmpty() || $userparam->intrecharge <= 0) {
  286. page_result(1, "禁止用户充值。");
  287. }
  288. $moneyvalue = input('moneyvalue/f', 0.00);
  289. $intvalue = intval($moneyvalue * $userparam->intrecharge);
  290. if ($moneyvalue <= 0.00 || $intvalue <= 0) {
  291. page_result(1, "充值积分额不能小于0。");
  292. }
  293. $integral = new UserIntegralModel;
  294. $integral->save([
  295. 'userid' => $userid,
  296. 'title' => "用户积分充值(¥" . $moneyvalue . "元" . $intvalue . "积分)",
  297. 'intvalue' => $intvalue,
  298. 'intmoney' => $moneyvalue,
  299. 'onlycontent' => "",
  300. 'remark' => "R" . date("YmdHis") . mt_rand(100000, 999999),
  301. 'itype' => 2,
  302. 'status' => 1,
  303. 'createtime' => time(),
  304. 'yeartime' => date('Y'),
  305. 'monthtime' => date('Ym'),
  306. ]);
  307. $payData = [
  308. 'body' => "用户积分充值(¥" . $moneyvalue . "元" . $intvalue . "积分)",
  309. 'out_trade_no' => $integral->remark,
  310. 'total_fee' => intval($moneyvalue * 100),
  311. 'openid' => $userauths->identifier,
  312. ];
  313. $wxpay = new WxPay();
  314. $info = $wxpay->wxpay_unified_order($payData);
  315. if ($info['status'] == 1) {
  316. $payinfo = $wxpay->get_jsapi_param($info['data']['prepay_id']);
  317. page_result(0, "", ['payinfo' => $payinfo]);
  318. } else {
  319. page_result(1, $info['data']);
  320. }
  321. }
  322. public function getMoney()
  323. {
  324. $userid = input('userid/d', 0);
  325. $user = UserModel::findOrEmpty($userid);
  326. if ($user->isEmpty()) {
  327. page_result(1, "用户信息不存在。");
  328. }
  329. $bankcard = $user->bankcard;
  330. if (empty($bankcard) || empty($bankcard['number'])) {
  331. page_result(1, "请先完善个人银行卡信息。");
  332. }
  333. $oldintegral = UserIntegralModel::where(['userid' => $userid, 'itype' => 3, 'status' => 1])->findOrEmpty();
  334. if (!$oldintegral->isEmpty()) {
  335. page_result(1, "你已存在未处理的兑现申请,请耐心等待客服处理,处理完成后方可再次提交兑现申请。");
  336. }
  337. $userparam = UserParamModel::where(1)->findOrEmpty();
  338. if ($userparam->isEmpty() || $userparam->inttomoney <= 0) {
  339. page_result(1, "禁止用户提现。");
  340. }
  341. $intvalue = input('intvalue/d', 0);
  342. if ($intvalue <= 0 || $intvalue < intval($userparam->minintegral)) {
  343. page_result(1, "兑现积分值要大于" . $userparam->minintegral . "。");
  344. }
  345. if ($intvalue > intval($user->integral)) {
  346. page_result(1, "兑现积分值不能大于当前可用积分。");
  347. }
  348. $integral = new UserIntegralModel;
  349. $intmoney = sprintf("%.2f", floatval($intvalue / $userparam->inttomoney));
  350. $integral->save([
  351. 'userid' => $userid,
  352. 'title' => "用户积分兑现",
  353. 'intvalue' => 0 - $intvalue,
  354. 'intmoney' => $intmoney,
  355. 'onlycontent' => "",
  356. 'remark' => "用户积分兑现现金",
  357. 'itype' => 3,
  358. 'status' => 1,
  359. 'createtime' => time(),
  360. 'yeartime' => date('Y'),
  361. 'monthtime' => date('Ym'),
  362. ]);
  363. $hasintegral = intval($user->integral) - $intvalue;
  364. $user->save([
  365. 'integral' => $hasintegral,
  366. ]);
  367. page_result(0, "", [
  368. 'user' => $user,
  369. ]);
  370. }
  371. public function getIntegral()
  372. {
  373. $ppage = input('ppage/d', 1);
  374. $psize = input('psize/d', 20);
  375. $userid = input('userid/d', 0);
  376. if ($userid != 0) {
  377. $map[] = ['userid', '=', $userid];
  378. }
  379. $plist = UserIntegralModel::where($map)->order(['id' => 'desc'])->page($ppage)->limit($psize)->select()->append(['itype_text', 'status_text']);
  380. page_result(0, "", [
  381. 'plist' => $plist,
  382. 'pstatus' => $psize > count($plist) ? 'noMore' : 'more',
  383. ]);
  384. }
  385. // 银行卡信息
  386. public function editUserBankinfo()
  387. {
  388. $userid = input('userid/d', 0);
  389. $user = UserModel::findOrEmpty($userid);
  390. if ($user->isEmpty()) {
  391. page_result(1, "用户信息不存在");
  392. }
  393. $openbank = input('openbank/s', "");
  394. $account = input('account/s', "");
  395. $number = input('number/s', "");
  396. $bankcard = [
  397. 'openbank' => $openbank,
  398. 'account' => $account,
  399. 'number' => $number,
  400. ];
  401. $user->save(['bankcard' => $bankcard]);
  402. page_result(0, "", $user);
  403. }
  404. // 个人信息
  405. public function editUserInfo()
  406. {
  407. $userid = input('userid/d');
  408. $user = UserModel::findOrEmpty($userid);
  409. if ($user->isEmpty()) {
  410. page_result(1, "用户信息不存在");
  411. }
  412. $field = input('field/s');
  413. $value = input('value');
  414. $field_array = ['emp_time', 'com_cate', 'work_place'];
  415. if (in_array($field, $field_array)) {
  416. $value = json_decode($value, true);
  417. }
  418. $user->$field = $value;
  419. $user->save();
  420. page_result(0, "", $user);
  421. }
  422. public function perfectUserInfo()
  423. {
  424. $userid = input('userid/d');
  425. $user = UserModel::findOrEmpty($userid);
  426. if ($user->isEmpty()) {
  427. page_result(1, "用户信息不存在");
  428. }
  429. if ($user['is_perfect'] == 2) {
  430. $user->is_perfect = 1;
  431. $user->save();
  432. //发放佣金
  433. $balanceService = new BalanceService();
  434. $balanceService->add($userid,BalanceService::IMPROVERESUME);
  435. }
  436. /*$integralService = new IntegralService();
  437. $integralService->add($userid, IntegralService::IMPROVERESUME);*/
  438. page_result();
  439. }
  440. // 身份证认证
  441. public function editIdCard()
  442. {
  443. $userid = input('userid/d');
  444. $user = UserModel::findOrEmpty($userid);
  445. if ($user->isEmpty()) {
  446. page_result(1, "用户信息不存在");
  447. }
  448. $data = input('data');
  449. if (is_string($data)) {
  450. $data = json_decode($data, true);
  451. }
  452. $fileds = ['nickname', 'idcard', 'gender', 'birthday'];
  453. foreach ($data as $k => $v) {
  454. if (in_array($k, $fileds)) {
  455. $user->$k = $v;
  456. }
  457. }
  458. $user->save();
  459. page_result(0, "", $user);
  460. }
  461. // 提交实名认证审核
  462. public function setAuthStatus()
  463. {
  464. $userid = input('userid/d');
  465. $user = UserModel::findOrEmpty($userid);
  466. if ($user->isEmpty()) {
  467. page_result(1, "用户信息不存在");
  468. }
  469. if (empty($user->idcardzpic)) {
  470. page_result(1, "请上传上传身份证(头像页)照。");
  471. }
  472. if (empty($user->idcardfpic)) {
  473. page_result(1, "请上传上传身份证(国徽页)照。");
  474. }
  475. if (empty($user->idcard)) {
  476. page_result(1, "请填写身份证号。");
  477. }
  478. if (isIdCard($user->idcard) == false) {
  479. page_result(1, "请填写正确的身份证号。");
  480. }
  481. if (empty($user->realname)) {
  482. page_result(1, "请填写姓名。");
  483. }
  484. $user->save([
  485. 'authstatus' => 2,
  486. 'gender' => get_sex($user->idcard),
  487. 'birthday' => get_birthday($user->idcard),
  488. ]);
  489. $sms = new SmsService();
  490. $sms->examineSend('idcard_examine', [$userid]);
  491. page_result(0, "", $user);
  492. }
  493. public function jobintention_lst()
  494. {
  495. $plist = UserWill::select();
  496. page_result(0, "", [
  497. 'plist' => $plist,
  498. ]);
  499. }
  500. public function getauthimg()
  501. {
  502. $image_url = "//" . $_SERVER['SERVER_NAME'];
  503. $head1 = $image_url . "/static/images/head1.png";
  504. $head2 = $image_url . "/static/images/head2.png";
  505. page_result(0, "", [
  506. 'head1' => $head1,
  507. 'head2' => $head2,
  508. ]);
  509. }
  510. public function gettipnum()
  511. {
  512. $userid = input('userid/d');
  513. $comjobs_num = ComjobsLogModel::where('userid', $userid)->whereIn('status', [2, 3, 4])->count();
  514. $invite_num = ResumeInvite::where('userid', $userid)->where('status', 1)->count();
  515. page_result(0, "", [
  516. 'comjobs_num' => $comjobs_num,
  517. 'invite_num' => $invite_num,
  518. ]);
  519. }
  520. public function signin()
  521. {
  522. $userid = input('userid/d');
  523. $check = UserIntegralModel::where('createtime', '>=', strtotime(date('Y-m-d')))
  524. ->where('createtime', '<=', strtotime(date('Y-m-d 23:59:59')))
  525. ->where('userid', $userid)
  526. ->where('itype', 9)
  527. ->find();
  528. if (!empty($check)) {
  529. page_result(1, "今日已签到");
  530. }
  531. $integralService = new IntegralService();
  532. $integralService->add($userid, IntegralService::SINGIN, 9);
  533. page_result(0, "");
  534. }
  535. public function task()
  536. {
  537. $userid = input('userid/d');
  538. $param = UserParamModel::field(['improveresume', 'certification', 'entry', 'signin', 'sharejob', 'sharejobnum', 'taskimage'])->where(1)->find();
  539. $share_num = UserIntegralModel::where('createtime', '>=', strtotime(date('Y-m-d')))
  540. ->where('createtime', '<=', strtotime(date('Y-m-d 23:59:59')))
  541. ->where('userid', $userid)
  542. ->where('itype', 10)
  543. ->count();
  544. $check = UserIntegralModel::where('createtime', '>=', strtotime(date('Y-m-d')))
  545. ->where('createtime', '<=', strtotime(date('Y-m-d 23:59:59')))
  546. ->where('userid', $userid)
  547. ->where('itype', 9)
  548. ->find();
  549. $is_signin = empty($check) ? 2 : 1;
  550. page_result(0, "", ['tasklist' => $param, 'share_num' => $share_num, 'is_signin' => $is_signin]);
  551. }
  552. public function getmoneylist()
  553. {
  554. $ppage = input('ppage/d', 1);
  555. $psize = input('psize/d', 20);
  556. $userid = input('userid/d', 0);
  557. if ($userid != 0) {
  558. $map[] = ['userid', '=', $userid];
  559. }
  560. $plist = UserGetmoneyLogModel::where($map)->order(['id' => 'desc'])->page($ppage)->limit($psize)->select()->append(['itype_text', 'status_text']);
  561. page_result(0, "", [
  562. 'plist' => $plist,
  563. 'pstatus' => $psize > count($plist) ? 'noMore' : 'more',
  564. ]);
  565. }
  566. public function getmoneyparam()
  567. {
  568. $param = UserParamModel::where(1)->find();
  569. if (empty($param)) {
  570. $param['getmoney'] = [];
  571. }
  572. page_result(0, "", ['getmoney' => $param['getmoney']]);
  573. }
  574. public function cash()
  575. {
  576. $index = input('index/d', 1);
  577. $userid = input('userid/d', 0);
  578. //获取配置参数
  579. $param = UserParamModel::where(1)->find();
  580. if (empty($param) || empty($param['getmoney'])) {
  581. page_result(1, "参数未配置");
  582. }
  583. if (empty($param['getmoney'][$index])) {
  584. page_result(1, "参数错误");
  585. }
  586. $cash = $param['getmoney'][$index];
  587. //满足提现条件
  588. $user = UserModel::findOrEmpty($userid);
  589. if ($user['integral'] < ($cash['money'] * $param['inttomoney'])) {
  590. page_result(1, "积分不足");
  591. }
  592. $where = [
  593. ['userid', '=', $userid],
  594. ['money', '=', $cash['money']],
  595. ];
  596. if ($cash['type'] == 2) {
  597. $where = ['createtime', '>=', strtotime(date('Y-m-01'))];
  598. }
  599. $cash_count = UserGetmoneyLog::where($where)->count();
  600. if ($cash_count >= $cash['num']) {
  601. page_result(1, "超过次数限制");
  602. }
  603. //提现
  604. $batch_name = '晋江人力小程序用户提现';//转账的名称
  605. $out_trade_no = 'jfhd' . getUniId();//单号
  606. $openid = UserAuthsModel::where('userid', $userid)->where('identitytype', 'weixin')->value('identifier');//用户openid
  607. $detail = [];
  608. $transfers = new WechatTransfers();
  609. $detail[] = $transfers->getDetailList($out_trade_no, $cash['money'], $batch_name, $openid);
  610. $res = $transfers->transfers($batch_name, $detail);
  611. Log::record('用户提现:'.json_encode($res));
  612. //记录
  613. if (!empty($res['batch_id'])) {
  614. $point = $cash['money'] * $param['inttomoney'];
  615. UserGetmoneyLog::create([
  616. 'userid' => $userid,
  617. 'out_trade_no' => $out_trade_no,
  618. 'money' => $cash['money'],
  619. 'integral' => $point,
  620. 'remark' => '小程序用户提现',
  621. 'createtime' => time(),
  622. ]);
  623. $integral = new UserIntegralModel;
  624. $integral->save([
  625. 'userid' => $userid,
  626. 'title' => "用户提现",
  627. 'intvalue' => $point,
  628. 'intmoney' => 0.00,
  629. 'onlycontent' => "",
  630. 'remark' => "积分提现活动",
  631. 'itype' => 3,
  632. 'status' => 2,
  633. 'createtime' => time(),
  634. 'yeartime' => date("Y"),
  635. 'monthtime' => date("Ym"),
  636. ]);
  637. $user->integral -= $point;
  638. $user->save();
  639. }
  640. page_result(0, "提现成功", $user);
  641. }
  642. public function feedback()
  643. {
  644. $param = input('param.');
  645. $param['createtime'] = time();
  646. Feedback::create($param);
  647. page_result(0, "提交成功");
  648. }
  649. }