| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608 |
- <?php
- namespace plugin\admin\app\controller;
- use app\api\repositories\MoneyLogRepositories;
- use app\business\LoginBusiness;
- use app\business\StreamBusiness;
- use Illuminate\Support\Arr;
- use plugin\admin\app\model\BankCard;
- use plugin\admin\app\model\MyGood;
- use plugin\admin\app\model\Stream;
- use plugin\admin\app\model\UserIdentity;
- use Respect\Validation\Validator;
- use support\Db;
- use support\Request;
- use support\Response;
- use plugin\admin\app\model\User;
- use plugin\admin\app\controller\Crud;
- use support\exception\BusinessException;
- /**
- * 会员列表
- */
- class UserController extends Crud
- {
- /**
- * @var User
- */
- protected $model = null;
- /**
- * 构造函数
- * @return void
- */
- public function __construct()
- {
- $this->model = new User;
- }
- /**
- * 浏览
- * @return Response
- */
- public function index(): Response
- {
- return view('user/index');
- }
- /** 首页
- * @param Request $request
- * @return Response
- */
- public function select(Request $request): Response
- {
- $param = $request->all();
- $teamId = admin('team_id');
- $data = User::query()->where(function ($query) use ($param, $teamId) {
- if (is_numeric(Arr::get($param, 'money.1')) && is_numeric(Arr::get($param, 'money.0'))) {
- $query->whereBetween('money', [$param['money'][0], $param['money'][1]]);
- } elseif (is_numeric(Arr::get($param, 'money.0'))) {
- $query->where('money', '>=', $param['money'][0]);
- } elseif (is_numeric(Arr::get($param, 'money.1'))) {
- $query->where('money', '<=', $param['money'][1]);
- }
- if (is_numeric(Arr::get($param, 'money_one.1')) && is_numeric(Arr::get($param, 'money_one.0'))) {
- $query->whereBetween('money_one', [$param['money_one'][0], $param['money_one'][1]]);
- } elseif (is_numeric(Arr::get($param, 'money_one.0'))) {
- $query->where('money_one', '>=', $param['money_one'][0]);
- } elseif (is_numeric(Arr::get($param, 'money_one.1'))) {
- $query->where('money_one', '<=', $param['money_one'][1]);
- }
- if (is_numeric(Arr::get($param, 'money_two.1')) && is_numeric(Arr::get($param, 'money_two.0'))) {
- $query->whereBetween('money_two', [$param['money_two'][0], $param['money_two'][1]]);
- } elseif (is_numeric(Arr::get($param, 'money_two.0'))) {
- $query->where('money_two', '>=', $param['money_two'][0]);
- } elseif (is_numeric(Arr::get($param, 'integral.1'))) {
- $query->where('money_two', '<=', $param['money_two'][1]);
- }
- if (Arr::get($param, 'created_at.0') && Arr::get($param, 'created_at.1')) {
- $query->whereBetween('created_at', [$param['created_at'][0], $param['created_at'][1]]);
- } elseif (Arr::get($param, 'created_at.0')) {
- $query->where('created_at', '>=', $param['created_at'][0]);
- } elseif (Arr::get($param, 'created_at.1')) {
- $query->where('created_at', '<=', $param['created_at'][1]);
- }
- if (Arr::get($param, 'join_time.0') && Arr::get($param, 'join_time.1')) {
- $query->whereBetween('join_time', [$param['join_time'][0], $param['join_time'][1]]);
- } elseif (Arr::get($param, 'join_time.0')) {
- $query->where('join_time', '>=', $param['join_time'][0]);
- } elseif (Arr::get($param, 'join_time.1')) {
- $query->where('join_time', '<=', $param['join_time'][1]);
- }
- if (is_numeric(Arr::get($param, 'status'))) {
- $query->where('status', $param['status']);
- }
- if (Arr::get($param, 'name')) {
- $query->where('name', $param['name']);
- }
- if (Arr::get($param, 'mobile')) {
- $query->where('mobile', $param['mobile']);
- }
- if (Arr::get($param, 'is_autonym')) {
- $query->where('is_autonym', $param['is_autonym']);
- }
- if (Arr::get($param, 'id')) {
- $query->where('id', $param['id']);
- }
- if ($teamId) {
- $query->where('team_id', $teamId);
- }
- })->with('pidData:id,name,mobile');
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = $param['order'];
- }
- $data = $data->orderBy($param['field'], $order);
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- return json(['code' => 0, 'data' => $data['data'], 'msg' => 'ok', 'count' => $data['total']]);
- }
- /** 下级
- * @param Request $request
- * @return Response
- */
- public function subordinate(Request $request): Response
- {
- $param = $request->all();
- if ($request->isAjax()) {
- $data = User::query()->where(function ($query) use ($param) {
- if (is_numeric(Arr::get($param, 'money.1')) && is_numeric(Arr::get($param, 'money.0'))) {
- $query->whereBetween('money', [$param['money'][0], $param['money'][1]]);
- } elseif (is_numeric(Arr::get($param, 'money.0'))) {
- $query->where('money', '>=', $param['money'][0]);
- } elseif (is_numeric(Arr::get($param, 'money.1'))) {
- $query->where('money', '<=', $param['money'][1]);
- }
- if (Arr::get($param, 'created_at.0') && Arr::get($param, 'created_at.1')) {
- $query->whereBetween('created_at', [$param['created_at'][0], $param['created_at'][1]]);
- } elseif (Arr::get($param, 'created_at.0')) {
- $query->where('created_at', '>=', $param['created_at'][0]);
- } elseif (Arr::get($param, 'created_at.1')) {
- $query->where('created_at', '<=', $param['created_at'][1]);
- }
- if (is_numeric(Arr::get($param, 'status'))) {
- $query->where('status', $param['status']);
- }
- if (Arr::get($param, 'last_time.0') && Arr::get($param, 'last_time.1')) {
- $query->whereBetween('last_time', [$param['last_time'][0], $param['last_time'][1]]);
- } elseif (Arr::get($param, 'last_time.0')) {
- $query->where('last_time', '>=', $param['last_time'][0]);
- } elseif (Arr::get($param, 'last_time.1')) {
- $query->where('last_time', '<=', $param['last_time'][1]);
- }
- if (Arr::get($param, 'join_time.0') && Arr::get($param, 'join_time.1')) {
- $query->whereBetween('join_time', [$param['join_time'][0], $param['join_time'][1]]);
- } elseif (Arr::get($param, 'join_time.0')) {
- $query->where('join_time', '>=', $param['join_time'][0]);
- } elseif (Arr::get($param, 'last_time.1')) {
- $query->where('join_time', '<=', $param['join_time'][1]);
- }
- if (Arr::get($param, 'last_ip')) {
- $query->where('last_ip', $param['last_ip']);
- }
- if (Arr::get($param, 'join_ip')) {
- $query->where('join_ip', $param['join_ip']);
- }
- if (Arr::get($param, 'name')) {
- $query->where('name', $param['name']);
- }
- if (Arr::get($param, 'mobile')) {
- $query->where('mobile', $param['mobile']);
- }
- if (Arr::get($param, 'pid')) {
- $query->where('pid', $param['pid']);
- }
- });
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = 'desc';
- }
- $data = $data->orderBy($param['field'], $order);
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- return json(['code' => 0, 'data' => $data['data'], 'msg' => 'ok', 'count' => $data['total']]);
- }
- return view('user/subordinate', $param);
- }
- /** 流水
- * @param Request $request
- * @return Response
- */
- public function stream(Request $request): Response
- {
- $param = $request->all();
- if ($request->isAjax()) {
- $param = $request->all();
- $data = Stream::query()->where(function ($query) use ($param) {
- if (is_numeric(Arr::get($param, 'money.1')) && is_numeric(Arr::get($param, 'money.0'))) {
- $query->whereBetween('money', [$param['money'][0], $param['money'][1]]);
- } elseif (is_numeric(Arr::get($param, 'money.0'))) {
- $query->where('money', '>=', $param['money'][0]);
- } elseif (is_numeric(Arr::get($param, 'money.1'))) {
- $query->where('money', '<=', $param['money'][1]);
- }
- if (Arr::get($param, 'created_at.0') && Arr::get($param, 'created_at.1')) {
- $query->whereBetween('created_at', [$param['created_at'][0], $param['created_at'][1]]);
- } elseif (Arr::get($param, 'created_at.0')) {
- $query->where('created_at', '>=', $param['created_at'][0]);
- } elseif (Arr::get($param, 'created_at.1')) {
- $query->where('created_at', '<=', $param['created_at'][1]);
- }
- if (Arr::get($param, 'type')) {
- $query->where('type', $param['type']);
- }
- if (Arr::get($param, 'mold')) {
- $query->where('mold', $param['mold']);
- }
- if (Arr::get($param, 'user_id')) {
- $query->where('user_id', $param['user_id']);
- }
- })->whereExists(function ($query) use ($param) {
- $query->from('wa_users')->whereRaw('wa_users.id=wa_stream.user_id');
- if (Arr::get($param, 'user_name')) {
- $query->where('name', 'like', '%' . $param['user_name'] . '%');
- }
- if (Arr::get($param, 'mobile')) {
- $query->where('mobile', 'like', '%' . $param['mobile'] . '%');
- }
- })
- ->with('userData:id,name,mobile');
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = 'desc';
- }
- $data = $data->orderBy($param['field'], $order);
- } else {
- $data = $data->orderByDesc('id');
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- $arr = [];
- foreach ($data['data'] as $k => $v) {
- $arr[] = [
- 'user_name' => $v['user_data']['name'],
- 'user_mobile' => $v['user_data']['mobile'],
- 'type_id' => $v['type'],
- 'mold_id' => $v['mold'],
- 'type' => streamType($v['type']) . '--' . moldType($v['mold']),
- 'created_at' => $v['created_at'],
- 'total_money' => $v['total_money'],
- 'money' => $v['money']
- ];
- }
- return json(['code' => 0, 'data' => $arr, 'msg' => 'ok', 'count' => $data['total']]);
- }
- return view('user/stream', $param);
- }
- /** 银行卡
- * @param Request $request
- * @return Response
- */
- public function bankcard(Request $request): Response
- {
- $param = $request->all();
- if ($request->isAjax()) {
- $data = BankCard::query()->where(function ($query) use ($param) {
- if (Arr::get($param, 'id')) {
- $query->where('uid', $param['id']);
- }
- })->with('userData:id,name,mobile');
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = 'desc';
- }
- $data = $data->orderBy($param['field'], $order);
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- return json(['code' => 0, 'data' => $data['data'], 'msg' => 'ok', 'count' => $data['total']]);
- }
- return view('user/bankcard', $param);
- }
- /** 身份证
- * @param Request $request
- * @return Response
- */
- public function identity(Request $request): Response
- {
- $param = $request->all();
- if ($request->isAjax()) {
- $data = UserIdentity::query()->where(function ($query) use ($param) {
- if (Arr::get($param, 'id')) {
- $query->where('uid', $param['id']);
- }
- });
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = 'desc';
- }
- $data = $data->orderBy($param['field'], $order);
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- return json(['code' => 0, 'data' => $data['data'], 'msg' => 'ok', 'count' => $data['total']]);
- }
- return view('user/identity', $param);
- }
- /** 更新身份证
- * @param Request $request
- * @return Response
- */
- public function identitysave(Request $request): Response
- {
- $param = $request->all();
- $param = Arr::only($param, ['id', 'name', 'number']);
- if ($request->isAjax()) {
- try {
- $has = UserIdentity::query()->where('uid', $param['id'])->first();
- if ($has) {
- UserIdentity::query()->where('uid', $param['id'])->update([
- 'name' => $param['name'],
- 'number' => $param['number'],
- 'uid' => $param['id'],
- 'oname' => $has->name,
- 'onumber' => $has->number,
- ]);
- } else {
- UserIdentity::query()->insert([
- 'uid' => $param['id'],
- 'name' => $param['name'],
- 'number' => $param['number'],
- 'created_at' => date('Y-m-d H:i:s'),
- 'updated_at' => date('Y-m-d H:i:s'),
- ]);
- }
- User::query()->where('id', $param['id'])->update([
- 'is_autonym' => 1,
- 'name' => $param['name'],
- 'updated_at' => date('Y-m-d H:i:s')
- ]);
- } catch (\Throwable $exception) {
- return $this->fail($exception->getMessage());
- }
- return $this->success();
- }
- }
- /**
- * 更新
- * @param Request $request
- * @return Response
- * @throws BusinessException
- */
- public function update(Request $request): Response
- {
- if ($request->method() === 'POST') {
- $param = $request->all();
- Db::beginTransaction();
- try {
- Validator::input($param, [
- 'id' => Validator::notEmpty()->setName('标识'),
- ]);
- $userModel = User::query();
- $has = (clone $userModel)->where('id', $param['id'])->first();
- if (empty($has)) {
- throw new \Exception('账号不存在!');
- }
- if (Arr::get($param, 'name')) {
- $save['name'] = $param['name'];
- }
- if (Arr::get($param, 'is_claim')) {
- $save['is_claim'] = $param['is_claim'];
- }
- if (Arr::get($param, 'is_bank_withdraw')) {
- $save['is_bank_withdraw'] = $param['is_bank_withdraw'];
- }
- if (Arr::get($param, 'password')) {
- $save['password'] = md5($param['password']);
- }
- /** 修改手机号 */
- if (Arr::get($param, 'mobile') && $has->mobile != Arr::get($param, 'mobile')) {
- $hasMobile = (clone $userModel)->where('mobile', $param['mobile'])->exists();
- if (empty($hasMobile)) {
- $save['mobile'] = $param['mobile'];
- } else {
- throw new \Exception($param['mobile'] . '手机号已存在!');
- }
- }
- if (Arr::get($param, 'pid_mobile')) {
- $pid = (clone $userModel)->where('mobile', $param['pid_mobile'])->value('id');
- if (!empty($pid)) {
- $save['pid'] = $pid;
- (clone $userModel)->where('pid', $has->id)->update(['ppid' => $pid]);
- (clone $userModel)->where('ppid', $has->id)->update(['toppid' => $pid]);
- } else {
- throw new \Exception($param['pid_mobile'] . '未查询到您需要变更的上级信息,请确认手机号是否正确!');
- }
- }
- if (is_numeric(Arr::get($param, 'status'))) {
- $save['status'] = $param['status'];
- }
- (clone $userModel)->where('id', $param['id'])->update($save);
- } catch (\Throwable $exception) {
- Db::rollBack();
- return $this->fail($exception->getMessage());
- }
- Db::commit();
- return $this->success();
- }
- return view('user/update');
- }
- /**
- * 插入
- * @param Request $request
- * @return Response
- * @throws BusinessException
- */
- public function insert(Request $request): Response
- {
- if ($request->method() === 'POST') {
- $param = Arr::only($request->all(), ['mobile', 'password', 'invitation_code']);
- Db::beginTransaction();
- try {
- Validator::input($param, [
- 'mobile' => Validator::notEmpty()->intType()->setName('手机号'),
- 'password' => Validator::notEmpty()->stringType()->Length(6, 15)->alnum()->setName('密码'),
- 'invitation_code' => Validator::notEmpty()->intType()->setName('邀请码'),
- ]);
- LoginBusiness::register($param);
- } catch (\Throwable $exception) {
- Db::rollBack();
- return $this->fail($exception->getMessage());
- }
- Db::commit();
- return $this->success();
- }
- return view('user/insert');
- }
- /** 更新银行卡
- * @param Request $request
- * @return Response
- */
- public function bankcardsave(Request $request): Response
- {
- $param = $request->all();
- $param = Arr::only($param, ['id', 'affiliated_bank', 'account_holder', 'card_number']);
- if ($request->isAjax()) {
- try {
- $has = BankCard::query()->where('uid', $param['id'])->first();
- if ($has) {
- BankCard::query()->where('uid', $param['id'])->update([
- 'affiliated_bank' => $param['affiliated_bank'],
- 'account_holder' => $param['account_holder'],
- 'card_number' => $param['card_number'],
- 'o_account_holder' => $has->account_holder,
- 'o_affiliated_bank' => $has->affiliated_bank,
- 'o_card_number' => $has->card_number,
- ]);
- } else {
- BankCard::query()->insert([
- 'uid' => $param['id'],
- 'affiliated_bank' => $param['affiliated_bank'],
- 'account_holder' => $param['account_holder'],
- 'card_number' => $param['card_number'],
- ]);
- }
- } catch (\Throwable $exception) {
- return $this->fail($exception->getMessage());
- }
- return $this->success();
- }
- }
- /** 会员产品
- * @param Request $request
- * @return Response
- */
- public function goods(Request $request): Response
- {
- $param = $request->all();
- if ($request->isAjax()) {
- $teamId = admin('team_id');
- $data = MyGood::query()->where(function ($query) use ($param) {
- if (Arr::get($param, 'id')) {
- $query->where('user_id', $param['id']);
- }
- })->whereExists(function ($query) use ($teamId) {
- $query->from('wa_users')->whereRaw('wa_users.id=wa_my_goods.user_id');
- if (!empty($teamId)) {
- $query->where('team_id', $teamId);
- }
- })->with('userData:id,name');
- if (Arr::get($param, 'field')) {
- $order = 'asc';
- if (Arr::get($param, 'order')) {
- $order = 'desc';
- }
- $data = $data->orderBy($param['field'], $order);
- } else {
- $data = $data->orderByDesc('id');
- }
- $data = $data->paginate(Arr::get($param, 'limit', 10))->toArray();
- return json(['code' => 0, 'data' => $data['data'], 'msg' => 'ok', 'count' => $data['total']]);
- }
- return view('user/goods', $param);
- }
- /** 上下分
- * @param Request $request
- * @return Response
- */
- public function money(Request $request): Response
- {
- if ($request->method() === 'POST') {
- $param = $request->all();
- $param = Arr::only($param, ['id', 'type', 'buy', 'mold', 'operate_password']);
- Db::beginTransaction();
- try {
- Validator::input($param, [
- 'id' => Validator::notEmpty()->setName('标识'),
- 'type' => Validator::notEmpty()->setName('操作类型'),
- 'buy' => Validator::notEmpty()->setName('金额'),
- 'mold' => Validator::notEmpty()->setName('钱包'),
- // 'operate_password' => Validator::notEmpty()->setName('密码'),
- ]);
- // $system = Db::table('wa_system')->first();
- // if (md5($param['operate_password']) != $system->operate_password) {
- // throw new \Exception('密码填写错误!');
- // }
- if (Arr::get($param, 'type') == 1) {
- StreamBusiness::addStream($param['id'], $param['buy'], streamType7, $param['mold'], moldTypefild($param['mold']));
- } elseif (Arr::get($param, 'type') == 2) {
- StreamBusiness::delStream($param['id'], $param['buy'], streamType8, $param['mold'], moldTypefild($param['mold']));
- }
- } catch (\Throwable $exception) {
- Db::rollBack();
- return $this->fail($exception->getMessage());
- }
- Db::commit();
- return $this->success();
- }
- return view('user/money');
- }
- }
|