My.php 25 KB

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