My.php 24 KB

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