| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621 |
- <?php
- // +----------------------------------------------------------------------
- // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
- // +----------------------------------------------------------------------
- // | 版权所有 2017~2021 LARAVEL研发中心
- // +----------------------------------------------------------------------
- // | 官方网站: http://www.laravel.cn
- // +----------------------------------------------------------------------
- // | Author: laravel开发员 <laravel.qq.com>
- // +----------------------------------------------------------------------
- namespace App\Services\Common;
- use App\Http\Validator\MemberValidator;
- use App\Models\MemberModel;
- use App\Models\UserModel;
- use App\Services\BaseService;
- use App\Services\ConfigService;
- use App\Services\EmailService;
- use App\Services\SmsService;
- use App\Services\UsdtWalletService;
- use Earnp\GoogleAuthenticator\GoogleAuthenticator;
- /**
- * 用户管理-服务类
- * @author laravel开发员
- * @since 2020/11/11
- * Class UserService
- * @package App\Services\Common
- */
- class UserService extends BaseService
- {
- /**
- * 构造函数
- * @author laravel开发员
- * @since 2020/11/11
- * UserService constructor.
- */
- public function __construct()
- {
- $this->model = new UserModel();
- $this->memberModel = new MemberModel();
- }
- /**
- * 静态入口
- * @return static|null
- */
- public static function make()
- {
- if (!self::$instance) {
- self::$instance = (new static());
- }
- return self::$instance;
- }
- /**
- * 获取用户列表
- * @return array
- * @since 2020/11/11
- * @author laravel开发员
- */
- public function getList()
- {
- $param = request()->all();
- // 查询条件
- $map = [];
- // 用户账号
- $username = getter($param, "username");
- if ($username) {
- $map[] = ["username", 'like', "%{$username}%"];
- }
- // 用户姓名
- $realname = getter($param, "realname");
- if ($realname) {
- $map[] = ['realname', 'like', "%{$realname}%"];
- }
- // 用户性别
- $gender = getter($param, "gender");
- if ($gender) {
- $map[] = ['gender', '=', $gender];
- }
- // 用户类型
- $userType = getter($param, "user_type");
- if ($userType) {
- $map[] = ['user_type', '=', $userType];
- }
- return parent::getList($map); // TODO: Change the autogenerated stub
- }
- /**
- * @param $params
- * @param int $pageSize
- * @return array
- */
- public function getDataList($params, $pageSize = 15)
- {
- $where = ['a.mark' => 1];
- $status = isset($params['status'])? $params['status'] : 0;
- $userType = isset($params['user_type'])? $params['user_type'] : 1;
- $tradeType = isset($params['trade_type'])? $params['trade_type'] : 0;
- $parentId = isset($params['parent_id'])? $params['parent_id'] : 0;
- if($userType>0){
- $where['a.user_type'] = $userType;
- }
- if($tradeType>0){
- $where['m.trade_type'] = $tradeType;
- }
- if($parentId>0){
- $where['m.parent_id'] = $parentId;
- }
- if($status>0){
- $where['a.status'] = $status;
- }
- $list = $this->model->from('user as a')
- ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
- ->where($where)
- ->where(function ($query) use($params){
- $keyword = isset($params['username'])? $params['username'] : '';
- if($keyword){
- $query->where('a.username','like',"%{$keyword}%")->orWhere('m.username','like',"%{$keyword}%");
- }
- $realname = isset($params['realname'])? $params['realname'] : '';
- if($realname){
- $query->where('m.username','like',"%{$realname}%");
- }
- })
- ->select(['a.*','m.usdt_num','m.credit','m.is_online','m.login_time','m.exception_num','m.realname', 'm.username', 'm.idcard','m.idcard_check','m.idcard_front_img','m.idcard_back_img','m.idcard_hand_img','m.credit_score_img','m.trc_address','m.erc_hexaddress'])
- ->orderBy('a.create_time','desc')
- ->paginate($pageSize > 0 ? $pageSize : 9999999);
- $list = $list? $list->toArray() :[];
- if($list){
- foreach($list['data'] as &$item){
- $item['idcard_front_img'] = isset($item['idcard_front_img']) && $item['idcard_front_img']? get_image_url($item['idcard_front_img']) : '';
- $item['idcard_back_img'] = isset($item['idcard_back_img']) && $item['idcard_back_img']? get_image_url($item['idcard_back_img']) : '';
- $item['idcard_hand_img'] = isset($item['idcard_hand_img']) && $item['idcard_hand_img']? get_image_url($item['idcard_hand_img']) : '';
- $item['credit_score_img'] = isset($item['credit_score_img']) && $item['credit_score_img']? get_image_url($item['credit_score_img']) : '';
- if($item['login_time'] < time() - 3600){
- $item['is_online'] = 2;
- }
- $item['trc_num'] = '0.00';
- $item['trc_usdt_num'] = '0.00';
- $item['erc_num'] = '0.00';
- $item['erc_usdt_num'] = '0.00';
- if($item['user_type'] == 2){
- $trcNum = UsdtWalletService::make()->getTrxBalance($item['trc_address'], true);
- // $trcNum = 0;
- $item['trc_num'] = floatval($trcNum);
- $trcUsdtNum = UsdtWalletService::make()->getTrc20Usdt($item['trc_address'], true);
- // $trcUsdtNum = 0;
- $item['trc_usdt_num'] = floatval($trcUsdtNum);
- $ercNum = 0;
- // $ercNum = UsdtWalletService::make()->getErcBalance($item['erc_hexaddress'], true);
- $item['erc_num'] = floatval($ercNum);
- $ercUsdtNum = 0;
- // $ercUsdtNum = UsdtWalletService::make()->getErc20Usdt($item['erc_hexaddress'], true);
- $item['erc_usdt_num'] = floatval($ercUsdtNum);
- $date = isset($params['date']) ? $params['date'] : [];
- $item['trade_total'] = TradeOrderService::make()->getTotalByDate($item['user_id'],$date);
- $item['advert_total'] = AdvertOrderService::make()->getTotalByDate($item['user_id'],$date);
- }
- }
- }
- return [
- 'pageSize'=> $pageSize,
- 'total'=>isset($list['total'])? $list['total'] : 0,
- 'list'=> isset($list['data'])? $list['data'] : []
- ];
- }
- /**
- * 添加或编辑用户
- * @return array
- * @since 2020/11/11
- * @author laravel开发员
- */
- public function edit()
- {
- // 请求参数
- $data = request()->all();
- // 用户名
- $username = trim($data['username']);
- // 密码
- $password = trim($data['password']);
- // 添加时设置密码
- if (empty($data['id'])) {
- $data['password'] = get_password($password . md5($password.'otc'));
- // 用户名重复性验证
- $count = $this->model
- ->where("username", '=', $username)
- ->where("mark", "=", 1)
- ->count();
- if ($count > 0) {
- return returnJson("系统中已存在相同的用户名", false);
- }
- } else {
- if($password){
- $data['password'] = get_password($password . md5($password.'otc'));
- }
- // 用户名重复性验证
- $count = $this->model
- ->where("username", '=', $username)
- ->where("id", "<>", $data['id'])
- ->where("mark", "=", 1)
- ->count();
- if ($count > 0) {
- return returnJson("系统中已存在相同的用户名", false);
- }
- // 币商会员账号验证
- if($data['user_type'] == 2){
- // 用户名重复性验证
- $count = $this->memberModel
- ->where("username", '=', $username)
- ->where("id", "<>", $data['user_id'])
- ->where("mark", "=", 1)
- ->count();
- if ($count > 0) {
- return returnJson("系统中已存在相同的会员账号", false);
- }
- }
- }
- // 头像处理
- $adminId = isset($data['id'])? $data['id'] : 0;
- $avatar = isset($data['avatar']) ? trim($data['avatar']) : '';
- if (strpos($avatar, "temp")) {
- $data['avatar'] = save_image($avatar, 'user');
- } else {
- $data['avatar'] = str_replace(IMG_URL, "", $data['avatar']);
- }
- $error = "";
- $data['birthday'] = isset($data['birthday'])? $data['birthday'] : '000-00-00';
- $data['bond'] = isset($data['bond'])? $data['bond'] : '0';
- $data['create_time'] = isset($data['create_time'])? $data['create_time'] : time();
- // 谷歌验证码
- if(empty($adminId) || empty($data['google_secret'])){
- $google = GoogleAuthenticator::CreateSecret();
- $data['google_secret'] = isset($google['secret'])? $google['secret'] : '';
- }
- $this->model->startTrans();
- $result = $this->model->edit($data, $error);
- if (!$result) {
- $this->model->rollBack();
- return returnJson($error, false);
- }
- // 删除已存在的用户角色关系数据
- $userRoleService = new UserRoleService();
- $userRoleService->deleteUserRole($result);
- // 插入用户角色关系数据
- $userRoleService->insertUserRole($result, $data['role_ids']);
- // 新建币商会员账号
- $userId = isset($data['user_id'])? $data['user_id'] : 0;
- $ppassword = '123456';
- $data = [
- 'username'=> $username,
- 'realname'=> isset($data['realname'])? $data['realname'] : '',
- 'gender'=> isset($data['gender'])? $data['gender'] : 0,
- 'parent_id'=> isset($data['parent_id'])? intval($data['parent_id']) : 0,
- 'user_type'=> 2,
- 'mark'=> 1,
- 'status'=> 1,
- ];
- // 生成trc2.0钱包地址
- if(!$userId){
- $data['password'] = get_password($ppassword . md5($ppassword.'otc'));
- $trcAddress = UsdtWalletService::make()->getTrxAddress();
- if($trcAddress){
- $data['trc_wif'] = isset($trcAddress['wif'])? $trcAddress['wif'] : '';
- $data['trc_hexaddress'] = isset($trcAddress['hexAddress'])? $trcAddress['hexAddress'] : '';
- $data['trc_address'] = isset($trcAddress['address'])? $trcAddress['address'] : '';
- }else{
- $this->model->rollBack();
- return returnJson('生成TRC钱包地址失败', false);
- }
- // 生erc2.0钱包地址
- $ercAddress = UsdtWalletService::make()->getErcAddress();
- if($trcAddress){
- $data['erc_wif'] = isset($ercAddress['wif'])? $ercAddress['wif'] : '';
- $data['erc_hexaddress'] = isset($ercAddress['hexAddress'])? $ercAddress['hexAddress'] : '';
- $data['erc_address'] = isset($ercAddress['address'])? $ercAddress['address'] : '';
- }else{
- $this->model->rollBack();
- return returnJson('生成ERC钱包地址失败', false);
- }
- }
- $info = $this->memberModel->getInfo($userId);
- if($info){
- if(!$this->memberModel->where(['id'=> $userId])->update($data)){
- $this->model->rollBack();
- return returnJson('修改交易员信息失败', false);
- }
- $this->model->commit();
- $this->model->where(['id'=> $adminId])->update(['user_id'=> $userId]);
- }else{
- if(!$userId = $this->memberModel->edit($data)){
- $this->model->rollBack();
- return returnJson($userId? '修改交易员信息失败':'创建交易员账号失败', false);
- }
- $this->model->commit();
- // 更新绑定会员账号
- $this->model->where(['id'=> $result])->update(['user_id'=> $userId]);
- // 用户交易配置
- MemberSettingService::make()->getInfo($userId);
- }
- return returnJson();
- }
- /**
- * 获取用户信息
- * @param $id 用户ID
- * @return array
- * @author laravel开发员
- * @since 2020/11/10
- */
- public function getUserInfo($id)
- {
- $userInfo = $this->model->getInfo($id);
- $userInfo['roles'] = [];
- $userInfo['authorities'] = [];
- // 权限节点列表
- $menuService = new MenuService();
- $permissionList = $menuService->getPermissionsList($id);
- $userInfo['permissionList'] = $permissionList;
- return returnJson("操作成功", true, $userInfo);
- }
- /**
- * 获取当前会员的后台用户信息
- * @param $userId
- * @return mixed
- */
- public function getUserInfoByUserId($userId)
- {
- return $this->model->where(['user_id'=> $userId,'mark'=> 1])->first();
- }
- /**
- * 更新个人资料
- * @author laravel开发员
- * @since 2020/11/11
- */
- public function updateUserInfo($userId)
- {
- // 参数
- $param = request()->all();
- // 个人信息
- $data = [
- 'id' => $userId,
- 'realname' => $param['realname'],
- 'nickname' => $param['nickname'],
- ];
- // 头像处理
- $avatar = isset($param['avatar']) ? $param['avatar'] : "";
- if (strpos($avatar, "data:image") !== false) {
- $expData = explode(';', $avatar);
- $fileInfo = explode('/', $expData[0]);
- $fileExt = $fileInfo[1] == 'jpeg' ? 'jpg' : $fileInfo[1];
- // 文件存储路径
- $filePath = create_image_path("user", $fileExt);
- // 获取图片流
- $item = explode(',', $avatar);
- file_put_contents(ATTACHMENT_PATH . $filePath, base64_decode($item[1]));
- $data['avatar'] = $filePath;
- } else {
- $data['avatar'] = str_replace(IMG_URL, "", $param['avatar']);
- }
- $result = $this->model->edit($data);
- if (!$result) {
- return returnJson("更新资料信息失败", false);
- }
- return returnJson("更新资料信息成功");
- }
- /**
- * 认证资料
- */
- public function authSubmit($userId)
- {
- // 参数
- $param = request()->all();
- // 个人信息
- $data = [
- 'realname' => $param['realname'],
- 'idcard' => $param['idcard'],
- 'idcard_check' => 2,
- 'update_time' => time(),
- ];
- if (isset($param['idcard_front_img']) && strpos($param['idcard_front_img'], "temp")) {
- $data['idcard_front_img'] = save_image($param['idcard_front_img'], 'member');
- } else {
- $image = $param['idcard_front_img']? explode('/uploads', $param['idcard_front_img']) : [];
- $data['idcard_front_img'] = isset($image[1])? $image[1] : '';
- }
- if (isset($param['idcard_back_img']) && strpos($param['idcard_back_img'], "temp")) {
- $data['idcard_back_img'] = save_image($param['idcard_back_img'], 'member');
- } else {
- $image = $param['idcard_back_img']? explode('/uploads', $param['idcard_back_img']) : [];
- $data['idcard_back_img'] = isset($image[1])? $image[1] : '';
- }
- if (isset($param['idcard_hand_img']) && strpos($param['idcard_hand_img'], "temp")) {
- $data['idcard_hand_img'] = save_image($param['idcard_hand_img'], 'member');
- } else {
- $image = $param['idcard_hand_img']? explode('/uploads', $param['idcard_hand_img']) : [];
- $data['idcard_hand_img'] = isset($image[1])? $image[1] : '';
- }
- if (isset($param['credit_score_img']) && strpos($param['credit_score_img'], "temp")) {
- $data['credit_score_img'] = save_image($param['credit_score_img'], 'member');
- } else {
- $image = $param['credit_score_img']? explode('/uploads', $param['credit_score_img']) : [];
- $data['credit_score_img'] = isset($image[1])? $image[1] : '';
- }
- $info = $this->memberModel->getInfo($userId);
- if($info['idcard_check'] == 1){
- return returnJson("抱歉您已完成认证,不需再提交资料", false);
- }
- $this->memberModel->where(['id'=> $userId])->update($data);
- return returnJson("提交认证资料成功,请耐心等候审核");
- }
- /**
- * 更新密码
- * @param $userId 用户ID
- * @return array
- * @author laravel开发员
- * @since 2020/11/14
- */
- public function updatePwd($userId)
- {
- // 获取参数
- $param = request()->all();
- // 原始密码
- $oldPassword = trim(getter($param, "oldPassword"));
- if (!$oldPassword) {
- return returnJson("旧密码不能为空", false);
- }
- // 新密码
- $newPassword = trim(getter($param, "newPassword"));
- if (!$newPassword) {
- return returnJson("新密码不能为空", false);
- }
- $userInfo = $this->model->getInfo($userId);
- if (!$userInfo) {
- return returnJson("用户信息不存在", false);
- }
- if ($userInfo['password'] != get_password($oldPassword . md5($oldPassword.'otc'))) {
- return returnJson("旧密码输入不正确", false);
- }
- // 设置新密码
- $userInfo['password'] = get_password($newPassword . md5($newPassword.'otc'));
- $result = $this->model->edit($userInfo);
- if (!$result) {
- return returnJson("修改失败", false);
- }
- return returnJson("修改成功");
- }
- /**
- * 更新交易密码
- * @param $userId 用户ID
- * @param $adminId 管理ID
- * @return array
- * @author laravel开发员
- * @since 2020/11/14
- */
- public function updateTradePwd($userId, $adminId)
- {
- // 获取参数
- $param = request()->all();
- // 原始密码
- $loginPassword = trim(getter($param, "loginPassword"));
- if (!$loginPassword) {
- return returnJson("登录密码不能为空", false);
- }
- // 新密码
- $newPassword = trim(getter($param, "newPassword"));
- if (!$newPassword) {
- return returnJson("新密码不能为空", false);
- }
- $userInfo = $this->model->getInfo($adminId);
- $memberInfo = MemberService::make()->getInfo($userId);
- if (!$userInfo || empty($memberInfo)) {
- return returnJson("用户信息不存在", false);
- }
- if ($userInfo['password'] != get_password($loginPassword . md5($loginPassword.'otc'))) {
- return returnJson("登录密码输入不正确", false);
- }
- // 设置新密码
- $password = get_password($newPassword . md5($newPassword.'otc'));
- $result = $this->memberModel->where(['id'=> $userId])->update(['trade_password'=> $password]);
- if (!$result) {
- return returnJson("交易密码更新设置失败", false);
- }
- return returnJson("交易密码更新设置成功");
- }
- /**
- * 更新谷歌验证码
- * @param $userId 用户ID
- * @return array
- */
- public function updateGoogle($userId)
- {
- // 获取参数
- $param = request()->all();
- // 验证码
- $code = trim(getter($param, "code"));
- $username = trim(getter($param, "username"));
- if(empty($username)){
- return returnJson("账号参数错误", false);
- }
- if (!$code) {
- return returnJson("验证码不能为空", false);
- }
- // 验证码
- $validator = new MemberValidator();
- if(!is_array($validator->check(['mobile'=> $username],'mobile'))){
- if(!EmailService::make()->check($username, $code, 'google')){
- return returnJson(EmailService::make()->getError(), false);
- }
- }else{
- if(!SmsService::make()->check($username, $code, 'google')){
- return returnJson(SmsService::make()->getError(), false);
- }
- }
- //
- $googleCode = trim(getter($param, "google_code"));
- if (!$googleCode) {
- return returnJson("谷歌验证码不能为空", false);
- }
- $userInfo = $this->model->getInfo($userId);
- if (!$userInfo) {
- return returnJson("用户信息不存在", false);
- }
- // 谷歌验证码
- $googleSecret = isset($userInfo['google_secret'])? $userInfo['google_secret'] : '';
- if(empty($googleSecret)){
- return returnJson("您尚未绑定谷歌验证码", false);
- }
- if (!GoogleAuthenticator::CheckCode($googleSecret, $googleCode)) {
- return returnJson("谷歌验证码错误", false);
- }
- // 设置新谷歌验证码
- $google = GoogleAuthenticator::CreateSecret();
- $googleSecret = isset($google['secret'])? $google['secret'] : '';
- $googleLimitTime = ConfigService::make()->getConfigByCode('google_limit_time');
- $googleLimitTime = $googleLimitTime>0? $googleLimitTime : 1;
- $result = $this->model->where(['id'=> $userId])->update(['google_secret'=> $googleSecret,'google_verify_time'=> time() + $googleLimitTime*3600]);
- if (!$result) {
- return returnJson("谷歌验证码更新设置失败", false);
- }
- return returnJson("谷歌验证码更新设置成功");
- }
- /**
- * 重置密码
- * @return array
- * @since 2020/11/14
- * @author laravel开发员
- */
- public function resetPwd()
- {
- // 获取参数
- $param = request()->all();
- // 用户ID
- $userId = getter($param, "id");
- if (!$userId) {
- return returnJson("用户ID不能为空", false);
- }
- $userInfo = $this->model->getInfo($userId);
- if (!$userInfo) {
- return returnJson("用户信息不存在", false);
- }
- // 设置新密码
- $userInfo['password'] = get_password("123456" . md5('123456'.'otc'));
- $result = $this->model->edit($userInfo);
- if (!$result) {
- return returnJson("重置密码失败", false);
- }
- return returnJson("重置密码成功");
- }
- }
|