123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687 |
- <?php
- namespace app\api\controller\user;
- use app\http\validates\user\AddressValidate;
- use app\models\game\DayAward;
- use app\models\system\SystemCity;
- use app\models\user\UserSpread;
- use app\models\user\UserVisit;
- use think\db\exception\DataNotFoundException;
- use think\db\exception\DbException;
- use think\db\exception\ModelNotFoundException;
- use think\exception\ValidateException;
- use app\Request;
- use app\models\user\UserLevel;
- use app\models\user\UserSign;
- use app\models\store\StoreBargain;
- use app\models\store\StoreCombination;
- use app\models\store\StoreCouponUser;
- use app\models\store\StoreOrder;
- use app\models\store\StoreProductRelation;
- use app\models\store\StoreSeckill;
- use app\models\user\User;
- use app\models\user\UserAddress;
- use app\models\user\UserBill;
- use app\models\user\UserExtract;
- use app\models\user\UserNotice;
- use crmeb\services\GroupDataService;
- use crmeb\services\UtilService;
- /**
- * 用户类
- * Class UserController
- * @package app\api\controller\store
- */
- class UserController
- {
- /**
- * 获取用户信息
- * @param Request $request
- * @return mixed
- */
- public function userInfo(Request $request)
- {
- $info = $request->user()->toArray();
- $broken_time = intval(sys_config('extract_time'));
- $search_time = time() - 86400 * $broken_time;
- //返佣 +
- $brokerage_commission = UserBill::where(['uid' => $info['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
- ->where('add_time', '>', $search_time)
- ->where('pm', 1)
- ->sum('number');
- //退款退的佣金 -
- $refund_commission = UserBill::where(['uid' => $info['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
- ->where('add_time', '>', $search_time)
- ->where('pm', 0)
- ->sum('number');
- $info['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
- if ($info['broken_commission'] < 0)
- $info['broken_commission'] = 0;
- $info['commissionCount'] = bcsub($info['brokerage_price'], $info['broken_commission'], 2);
- if ($info['commissionCount'] < 0)
- $info['commissionCount'] = 0;
- return app('json')->success($info);
- }
- /**
- * 用户资金统计
- * @param Request $request
- * @return mixed
- * @throws \think\Exception
- * @throws DataNotFoundException
- * @throws ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public function balance(Request $request)
- {
- $uid = $request->uid();
- $user['now_money'] = User::getUserInfo($uid, 'now_money')['now_money'];//当前总资金
- $user['recharge'] = UserBill::getRecharge($uid);//累计充值
- $user['orderStatusSum'] = StoreOrder::getOrderStatusSum($uid);//累计消费
- return app('json')->successful($user);
- }
- /**
- * 个人中心
- * @param Request $request
- * @return mixed
- */
- public function user(Request $request)
- {
- $user = $request->user();
- $user = $user->toArray();
- $user['couponCount'] = StoreCouponUser::getUserValidCouponCount($user['uid']);
- $user['like'] = StoreProductRelation::getUserIdCollect($user['uid']);
- $user['orderStatusNum'] = StoreOrder::getOrderData($user['uid']);
- $user['notice'] = UserNotice::getNotice($user['uid']);
- // $user['brokerage'] = UserBill::getBrokerage($user['uid']);//获取总佣金
- $user['recharge'] = UserBill::getRecharge($user['uid']);//累计充值
- $user['orderStatusSum'] = StoreOrder::getOrderStatusSum($user['uid']);//累计消费
- $user['extractTotalPrice'] = UserExtract::userExtractTotalPrice($user['uid']);//累计提现
- $user['extractPrice'] = $user['brokerage_price'];//可提现
- $user['statu'] = (int)sys_config('store_brokerage_statu');
- $broken_time = intval(sys_config('extract_time'));
- $search_time = time() - 86400 * $broken_time;
- if (!$user['is_promoter'] && $user['statu'] == 2) {
- $price = StoreOrder::where(['paid' => 1, 'refund_status' => 0, 'uid' => $user['uid']])->sum('pay_price');
- $status = is_brokerage_statu($price);
- if ($status) {
- User::where('uid', $user['uid'])->update(['is_promoter' => 1]);
- $user['is_promoter'] = 1;
- } else {
- $storeBrokeragePrice = sys_config('store_brokerage_price', 0);
- $user['promoter_price'] = bcsub($storeBrokeragePrice, $price, 2);
- }
- }
- //可提现佣金
- //返佣 +
- $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
- ->where('add_time', '>', $search_time)
- ->where('pm', 1)
- ->sum('number');
- //退款退的佣金 -
- $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
- ->where('add_time', '>', $search_time)
- ->where('pm', 0)
- ->sum('number');
- $user['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
- if ($user['broken_commission'] < 0)
- $user['broken_commission'] = 0;
- $user['commissionCount'] = bcsub($user['brokerage_price'], $user['broken_commission'], 2);
- if ($user['commissionCount'] < 0)
- $user['commissionCount'] = 0;
- if (!sys_config('vip_open'))
- $user['vip'] = false;
- else {
- $vipId = UserLevel::getUserLevel($user['uid']);
- $user['vip'] = $vipId !== false ? true : false;
- if ($user['vip']) {
- $user['vip_id'] = $vipId;
- $user['vip_icon'] = UserLevel::getUserLevelInfo($vipId, 'icon');
- $user['vip_name'] = UserLevel::getUserLevelInfo($vipId, 'name');
- }
- }
- $user['yesterDay'] = UserBill::yesterdayCommissionSum($user['uid']);
- $user['recharge_switch'] = (int)sys_config('recharge_switch');//充值开关
- $user['adminid'] = (boolean)\app\models\store\StoreService::orderServiceStatus($user['uid']);
- if ($user['phone'] && $user['user_type'] != 'h5') {
- $user['switchUserInfo'][] = $request->user();
- if ($h5UserInfo = User::where('account', $user['phone'])->where('user_type', 'h5')->find()) {
- $user['switchUserInfo'][] = $h5UserInfo;
- }
- } else if ($user['phone'] && $user['user_type'] == 'h5') {
- if ($wechatUserInfo = User::where('phone', $user['phone'])->where('user_type', '<>', 'h5')->find()) {
- $user['switchUserInfo'][] = $wechatUserInfo;
- }
- $user['switchUserInfo'][] = $request->user();
- } else if (!$user['phone']) {
- $user['switchUserInfo'][] = $request->user();
- }
- return app('json')->successful($user);
- }
- /**
- * 地址 获取单个
- * @param Request $request
- * @param $id
- * @return mixed
- * @throws DataNotFoundException
- * @throws ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public function address(Request $request, $id)
- {
- $addressInfo = [];
- if ($id && is_numeric($id) && UserAddress::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()])) {
- $addressInfo = UserAddress::find($id)->toArray();
- }
- return app('json')->successful($addressInfo);
- }
- /**
- * 地址列表
- * @param Request $request
- * @param $page
- * @param $limit
- * @return mixed
- */
- public function address_list(Request $request)
- {
- list($page, $limit) = UtilService::getMore([['page', 0], ['limit', 20]], $request, true);
- $list = UserAddress::getUserValidAddressList($request->uid(), $page, $limit, 'id,real_name,phone,province,city,district,detail,is_default');
- return app('json')->successful($list);
- }
- /**
- * 设置默认地址
- *
- * @param Request $request
- * @return mixed
- */
- public function address_default_set(Request $request)
- {
- list($id) = UtilService::getMore([['id', 0]], $request, true);
- if (!$id || !is_numeric($id)) return app('json')->fail('参数错误!');
- if (!UserAddress::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()]))
- return app('json')->fail('地址不存在!');
- $res = UserAddress::setDefaultAddress($id, $request->uid());
- if (!$res)
- return app('json')->fail('地址不存在!');
- else
- return app('json')->successful();
- }
- /**
- * 获取默认地址
- * @param Request $request
- * @return mixed
- */
- public function address_default(Request $request)
- {
- $defaultAddress = UserAddress::getUserDefaultAddress($request->uid(), 'id,real_name,phone,province,city,district,detail,is_default');
- if ($defaultAddress) {
- $defaultAddress = $defaultAddress->toArray();
- return app('json')->successful('ok', $defaultAddress);
- }
- return app('json')->successful('empty', []);
- }
- /**
- * 修改 添加地址
- * @param Request $request
- * @return mixed
- */
- public function address_edit(Request $request)
- {
- $addressInfo = UtilService::postMore([
- ['address', []],
- ['is_default', false],
- ['real_name', ''],
- ['post_code', ''],
- ['phone', ''],
- ['detail', ''],
- ['id', 0],
- ['type', 0]
- ], $request);
- if (!isset($addressInfo['address']['province'])) return app('json')->fail('收货地址格式错误!');
- if (!isset($addressInfo['address']['city'])) return app('json')->fail('收货地址格式错误!');
- if (!isset($addressInfo['address']['district'])) return app('json')->fail('收货地址格式错误!');
- if (!isset($addressInfo['address']['city_id']) && $addressInfo['type'] == 0) {
- return app('json')->fail('收货地址格式错误!请重新选择!');
- } else if ($addressInfo['type'] == 1) {
- $city = $addressInfo['address']['city'];
- $cityId = SystemCity::where('name', $city)->where('parent_id', '<>', 0)->value('city_id');
- if ($cityId) {
- $addressInfo['address']['city_id'] = $cityId;
- } else {
- if (!($cityId = SystemCity::where('parent_id', '<>', 0)->where('name', 'like', "%$city%")->value('city_id'))) {
- return app('json')->fail('收货地址格式错误!修改后请重新导入!');
- }
- $addressInfo['address']['city_id'] = $cityId;
- }
- }
- $addressInfo['province'] = $addressInfo['address']['province'];
- $addressInfo['city'] = $addressInfo['address']['city'];
- $addressInfo['city_id'] = $addressInfo['address']['city_id'] ?? 0;
- $addressInfo['district'] = $addressInfo['address']['district'];
- $addressInfo['is_default'] = (int)$addressInfo['is_default'] == true ? 1 : 0;
- $addressInfo['uid'] = $request->uid();
- unset($addressInfo['address'], $addressInfo['type']);
- try {
- validate(AddressValidate::class)->check($addressInfo);
- } catch (ValidateException $e) {
- return app('json')->fail($e->getError());
- }
- if ($addressInfo['id'] && UserAddress::be(['id' => $addressInfo['id'], 'uid' => $request->uid(), 'is_del' => 0])) {
- $id = $addressInfo['id'];
- unset($addressInfo['id']);
- if (UserAddress::edit($addressInfo, $id, 'id')) {
- if ($addressInfo['is_default'])
- UserAddress::setDefaultAddress($id, $request->uid());
- return app('json')->successful();
- } else
- return app('json')->fail('编辑收货地址失败!');
- } else {
- $addressInfo['add_time'] = time();
- if ($address = UserAddress::create($addressInfo)) {
- if ($addressInfo['is_default']) {
- UserAddress::setDefaultAddress($address->id, $request->uid());
- }
- return app('json')->successful(['id' => $address->id]);
- } else {
- return app('json')->fail('添加收货地址失败!');
- }
- }
- }
- /**
- * 删除地址
- *
- * @param Request $request
- * @return mixed
- */
- public function address_del(Request $request)
- {
- list($id) = UtilService::postMore([['id', 0]], $request, true);
- if (!$id || !is_numeric($id)) return app('json')->fail('参数错误!');
- if (!UserAddress::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()]))
- return app('json')->fail('地址不存在!');
- if (UserAddress::edit(['is_del' => '1'], $id, 'id'))
- return app('json')->successful();
- else
- return app('json')->fail('删除地址失败!');
- }
- /**
- * 获取收藏产品
- *
- * @param Request $request
- * @return mixed
- */
- public function collect_user(Request $request)
- {
- list($page, $limit) = UtilService::getMore([
- ['page', 0],
- ['limit', 0]
- ], $request, true);
- if (!(int)$limit) return app('json')->successful([]);
- $productRelationList = StoreProductRelation::getUserCollectProduct($request->uid(), (int)$page, (int)$limit);
- return app('json')->successful($productRelationList);
- }
- /**
- * 添加收藏
- * @param Request $request
- * @param $id
- * @param $category
- * @return mixed
- */
- public function collect_add(Request $request)
- {
- list($id, $category) = UtilService::postMore([['id', 0], ['category', 'product']], $request, true);
- if (!$id || !is_numeric($id)) return app('json')->fail('参数错误');
- $res = StoreProductRelation::productRelation($id, $request->uid(), 'collect', $category);
- if (!$res) return app('json')->fail(StoreProductRelation::getErrorInfo());
- else return app('json')->successful();
- }
- /**
- * 取消收藏
- *
- * @param Request $request
- * @return mixed
- */
- public function collect_del(Request $request)
- {
- list($id, $category) = UtilService::postMore([['id', 0], ['category', 'product']], $request, true);
- if (!$id || !is_numeric($id)) return app('json')->fail('参数错误');
- $res = StoreProductRelation::unProductRelation($id, $request->uid(), 'collect', $category);
- if (!$res) return app('json')->fail(StoreProductRelation::getErrorInfo());
- else return app('json')->successful();
- }
- /**
- * 批量收藏
- * @param Request $request
- * @return mixed
- */
- public function collect_all(Request $request)
- {
- $collectInfo = UtilService::postMore([
- ['id', []],
- ['category', 'product'],
- ], $request);
- if (!count($collectInfo['id'])) return app('json')->fail('参数错误');
- $productIdS = $collectInfo['id'];
- $res = StoreProductRelation::productRelationAll($productIdS, $request->uid(), 'collect', $collectInfo['category']);
- if (!$res) return app('json')->fail(StoreProductRelation::getErrorInfo());
- else return app('json')->successful('收藏成功');
- }
- /**
- * 添加点赞
- *
- * @param Request $request
- * @return mixed
- */
- // public function like_add(Request $request)
- // {
- // list($id, $category) = UtilService::postMore([['id',0], ['category','product']], $request, true);
- // if(!$id || !is_numeric($id)) return app('json')->fail('参数错误');
- // $res = StoreProductRelation::productRelation($id,$request->uid(),'like',$category);
- // if(!$res) return app('json')->fail(StoreProductRelation::getErrorInfo());
- // else return app('json')->successful();
- // }
- /**
- * 取消点赞
- *
- * @param Request $request
- * @return mixed
- */
- // public function like_del(Request $request)
- // {
- // list($id, $category) = UtilService::postMore([['id',0], ['category','product']], $request, true);
- // if(!$id || !is_numeric($id)) return app('json')->fail('参数错误');
- // $res = StoreProductRelation::unProductRelation($id, $request->uid(),'like',$category);
- // if(!$res) return app('json')->fail(StoreProductRelation::getErrorInfo());
- // else return app('json')->successful();
- // }
- /**
- * 签到 配置
- * @return mixed
- * @throws DataNotFoundException
- * @throws ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public function sign_config()
- {
- $signConfig = sys_data('sign_day_num') ?? [];
- return app('json')->successful($signConfig);
- }
- /**
- * 签到 列表
- * @param Request $request
- * @param $page
- * @param $limit
- * @return mixed
- */
- public function sign_list(Request $request)
- {
- list($page, $limit) = UtilService::getMore([
- ['page', 0],
- ['limit', 0]
- ], $request, true);
- if (!$limit) return app('json')->successful([]);
- $signList = UserSign::getSignList($request->uid(), (int)$page, (int)$limit);
- if ($signList) $signList = $signList->toArray();
- return app('json')->successful($signList);
- }
- /**
- * 签到
- * @param Request $request
- * @return mixed
- */
- public function sign_integral(Request $request)
- {
- $signed = UserSign::getIsSign($request->uid());
- if ($signed) return app('json')->fail('已签到');
- if (false !== ($integral = UserSign::sign($request->uid())))
- return app('json')->successful('签到获得' . floatval($integral) . '积分', ['integral' => $integral]);
- return app('json')->fail(UserSign::getErrorInfo('签到失败'));
- }
- /**
- * 签到用户信息
- * @param Request $request
- * @return mixed
- */
- public function sign_user(Request $request)
- {
- list($sign, $integral, $all) = UtilService::postMore([
- ['sign', 0],
- ['integral', 0],
- ['all', 0],
- ], $request, true);
- $user = $request->user();
- //是否统计签到
- if ($sign || $all) {
- $user['sum_sgin_day'] = UserSign::getSignSumDay($user['uid']);
- $user['is_day_sgin'] = UserSign::getIsSign($user['uid']);
- $user['is_YesterDay_sgin'] = UserSign::getIsSign($user['uid'], 'yesterday');
- if (!$user['is_day_sgin'] && !$user['is_YesterDay_sgin']) {
- $user['sign_num'] = 0;
- }
- }
- //是否统计积分使用情况
- if ($integral || $all) {
- $user['sum_integral'] = (int)UserBill::getRecordCount($user['uid'], 'integral', 'sign,system_add,gain');
- $user['deduction_integral'] = (int)UserBill::getRecordCount($user['uid'], 'integral', 'deduction', '', true) ?? 0;
- $user['today_integral'] = (int)UserBill::getRecordCount($user['uid'], 'integral', 'sign,system_add,gain', 'today');
- }
- unset($user['pwd']);
- if (!$user['is_promoter']) {
- $user['is_promoter'] = (int)sys_config('store_brokerage_statu') == 2 ? true : false;
- }
- return app('json')->successful($user->hidden(['account', 'real_name', 'birthday', 'card_id', 'mark', 'partner_id', 'group_id', 'add_time', 'add_ip', 'phone', 'last_time', 'last_ip', 'spread_uid', 'spread_time', 'user_type', 'status', 'level', 'clean_time', 'addres'])->toArray());
- }
- /**
- * 签到列表(年月)
- *
- * @param Request $request
- * @return mixed
- */
- public function sign_month(Request $request)
- {
- list($page, $limit) = UtilService::getMore([
- ['page', 0],
- ['limit', 0]
- ], $request, true);
- if (!$limit) return app('json')->successful([]);
- $userSignList = UserSign::getSignMonthList($request->uid(), (int)$page, (int)$limit);
- return app('json')->successful($userSignList);
- }
- /**
- * 获取活动状态
- * @return mixed
- */
- public function activity()
- {
- $data['is_bargin'] = StoreBargain::validBargain() ? true : false;
- $data['is_pink'] = StoreCombination::getPinkIsOpen() ? true : false;
- $data['is_seckill'] = StoreSeckill::getSeckillCount() ? true : false;
- return app('json')->successful($data);
- }
- /**
- * 用户修改信息
- * @param Request $request
- * @return mixed
- */
- public function edit(Request $request)
- {
- list($avatar, $nickname) = UtilService::postMore([
- ['avatar', ''],
- ['nickname', ''],
- ], $request, true);
- if (User::editUser($avatar, $nickname, $request->uid())) return app('json')->successful('修改成功');
- return app('json')->fail('修改失败');
- }
- /**
- * 推广人排行
- * @param Request $request
- * @return mixed
- * @throws DataNotFoundException
- * @throws ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public function rank(Request $request)
- {
- $data = UtilService::getMore([
- ['page', ''],
- ['limit', ''],
- ['type', '']
- ], $request);
- $users = User::getRankList($data);
- return app('json')->success($users);
- }
- /**
- * 佣金排行
- * @param Request $request
- * @return mixed
- */
- public function brokerage_rank(Request $request)
- {
- $data = UtilService::getMore([
- ['page', ''],
- ['limit'],
- ['type']
- ], $request);
- return app('json')->success([
- 'rank' => User::brokerageRank($data),
- 'position' => User::currentUserRank($data['type'], $request->user()['brokerage_price'])
- ]);
- }
- /**
- * 添加访问记录
- * @param Request $request
- * @return mixed
- */
- public function set_visit(Request $request)
- {
- $data = UtilService::postMore([
- ['url', ''],
- ['stay_time', 0]
- ], $request);
- if ($data['url'] == '') return app('json')->fail('未获取页面路径');
- $data['uid'] = $request->uid();
- $data['ip'] = $request->ip();
- $data['add_time'] = time();
- $res = UserVisit::insert($data);
- if ($res) {
- return app('json')->success('添加访问记录成功');
- } else {
- return app('json')->fail('添加访问记录失败');
- }
- }
- /**
- * 静默绑定推广人
- * @param Request $request
- * @return mixed
- * @throws DataNotFoundException
- * @throws DbException
- * @throws ModelNotFoundException
- */
- public function spread(Request $request)
- {
- $puid = $request->post('puid/d', 0);
- $phone = $request->post('phone', '');
- if (!$puid) $puid = User::where('phone', $phone)->value('uid');
- if (!User::setSpread($puid, $request->uid())) {
- return app('json')->fail(UserSpread::getErrorInfo());
- }
- return app('json')->success('成功');
- }
- public function tradeIntegral(Request $request)
- {
- $user = $request->user();
- $uid = $user['uid'];
- list($num, $to_user_account) = UtilService::postMore(
- [
- ['num', 0],
- ['to_user_account', ''],
- ], $request, true);
- if (!$num || !$to_user_account) {
- return app('json')->fail('参数不足');
- }
- $to_uid = User::where('account', $to_user_account)->value('uid');
- if (!$to_uid) return app('json')->fail('目标用户不存在');
- $res = User::tradeIntegral($uid, $to_uid, $num);
- if ($res) {
- return app('json')->success('支付成功');
- } else {
- return app('json')->fail('支付失败:' . User::getErrorInfo('支付错误'));
- }
- }
- public function tradeYue(Request $request)
- {
- $user = $request->user();
- $uid = $user['uid'];
- list($num, $to_user_account) = UtilService::postMore(
- [
- ['num', 0],
- ['to_user_account', ''],
- ], $request, true);
- if (!$num || !$to_user_account) {
- return app('json')->fail('参数不足');
- }
- $to_uid = User::where('account', $to_user_account)->value('uid');
- if (!$to_uid) return app('json')->fail('目标用户不存在');
- $res = User::tradeYue($uid, $to_uid, $num);
- if ($res) {
- return app('json')->success('支付成功');
- } else {
- return app('json')->fail('支付失败:' . User::getErrorInfo('支付错误'));
- }
- }
- public function tradeCash(Request $request)
- {
- $user = $request->user();
- $uid = $user['uid'];
- list($num, $to_user_account) = UtilService::postMore(
- [
- ['num', 0],
- ['to_user_account', ''],
- ], $request, true);
- if (!$num || !$to_user_account) {
- return app('json')->fail('参数不足');
- }
- $to_uid = User::where('account', $to_user_account)->value('uid');
- if (!$to_uid) return app('json')->fail('目标用户不存在');
- $res = User::tradeCash($uid, $to_uid, $num);
- if ($res) {
- return app('json')->success('支付成功');
- } else {
- return app('json')->fail('支付失败:' . User::getErrorInfo('支付错误'));
- }
- }
- }
|