User.php 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. <?php
  2. namespace app\common\controller;
  3. use think\App;
  4. use app\enterprise\model\User as UserModel;
  5. use app\enterprise\model\Group;
  6. use app\admin\model\UserView;
  7. use think\facade\Session;
  8. use app\admin\model\UserSession;
  9. use think\facade\Db;
  10. use GatewayClient\Gateway;
  11. /**
  12. * 控制器基础类
  13. */
  14. class User
  15. {
  16. /**
  17. * Request实例
  18. * @var \think\Request
  19. */
  20. protected $request;
  21. /**
  22. * 应用实例
  23. * @var \think\App
  24. */
  25. protected $app;
  26. protected $lang;
  27. /**
  28. * 构造方法
  29. * @access public
  30. * @param App $app 应用对象
  31. */
  32. public function __construct(App $app)
  33. {
  34. Gateway::$registerAddress = config('gateway.registerAddress');
  35. $this->app = $app;
  36. $this->request = $this->app->request;
  37. $this->lang = request()->header('Lang', 'en');
  38. }
  39. public function login(){
  40. $token = $this->request->param('token');
  41. $lang = $this->request->param('Lang');
  42. $this->lang = $lang ? $lang : $this->lang;
  43. if (!$token) {
  44. return ret(lang('user.token_error'));
  45. }
  46. try {
  47. Db::startTrans();
  48. $user_id = UserSession::where('token',$token)->where('expire_time','>', time())->value('user_id');
  49. if(!$user_id){
  50. return ret(lang('user.token_error'));
  51. }
  52. $cs_uid = getAutoCsUid();
  53. $userInfo=UserModel::where('user_id', $user_id)->withoutField('register_ip,login_count,update_time,create_time')->find();
  54. if (!$userInfo['cs_uid']) {
  55. // 监听用户注册后的操作
  56. event('UserRegister',['user_id' => $userInfo['user_id'], 'realname' => $userInfo['realname'], 'language_code' => $this->lang]);
  57. }
  58. // 如果用户已经有设置
  59. $setting=$userInfo['setting'] ?: '';
  60. if($setting){
  61. $setting['hideMessageName']= $setting['hideMessageName']=='true' ? true : false;
  62. $setting['hideMessageTime']= $setting['hideMessageTime']=='true' ? true : false;
  63. $setting['avatarCricle']= $setting['avatarCricle']=='true' ? true : false;
  64. $setting['isVoice']= $setting['isVoice']=='true' ? true : false;
  65. $setting['sendKey']= 1;//(int)$setting['sendKey'];
  66. $userInfo['setting']=$setting;
  67. }
  68. if($userInfo['status']==1){
  69. return ret(lang('user.forbid'));
  70. }
  71. $update=[
  72. 'last_login_time'=>time(),
  73. 'last_login_ip'=>$this->request->ip(),
  74. 'login_count'=>Db::raw('login_count+1'),
  75. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  76. 'language' => $this->lang,
  77. ];
  78. if ($userInfo['cs_uid'] == 1 || $userInfo['cs_uid'] == 0) {
  79. $update['cs_uid'] = $cs_uid;
  80. }
  81. if (!empty($params['realname'])) {
  82. $update['realname'] = $params['realname'];
  83. }
  84. UserModel::where('user_id',$userInfo['user_id'])->update($update);
  85. //记录用户浏览
  86. if (!empty($_SERVER['HTTP_REFERER']))
  87. UserView::addData($_SERVER['HTTP_REFERER'],$userInfo['user_id']);
  88. Db::commit();
  89. } catch (\Exception $e) {
  90. Db::rollback();
  91. return error($e->getMessage());
  92. }
  93. //如果登录信息中含有client——id则自动进行绑定
  94. $client_id=$this->request->param('client_id');
  95. if($client_id){
  96. $cid=$this->request->header('cid','');
  97. $this->doBindUid($userInfo['user_id'],$client_id,$cid);
  98. }
  99. $userInfo['qrUrl']=getMainHost().'/scan/u/'.encryptIds($userInfo['user_id']);
  100. unset($userInfo['password'],$userInfo['salt']);
  101. $userInfo['displayName']=$userInfo['realname'];
  102. $userInfo['id']=$userInfo['user_id'];
  103. $authToken=UserModel::refreshToken($userInfo,$param['terminal'] ?? 'web');
  104. $data=[
  105. 'sessionId'=>Session::getId(),
  106. 'authToken'=>$authToken,
  107. 'userInfo'=>$userInfo
  108. ];
  109. return success(lang('user.loginOk'),$data);
  110. }
  111. //客户端登录
  112. public function login2(){
  113. $params=request()->param();
  114. $where['role'] = 0;
  115. if (empty($params['account']) || empty($params['uid']) || empty($params['from'])) {
  116. return ret(lang('参数错误'));
  117. }
  118. if (!empty($params['account'])) {
  119. $where[] = ['account', '=', $params['account']];
  120. }
  121. if (!empty($params['from'])) {
  122. $where[] = ['from', '=', $params['from']];
  123. }
  124. if (!empty($params['uid'])) {
  125. $where[] = ['uid', '=', $params['uid']];
  126. }
  127. try {
  128. Db::startTrans();
  129. $cs_uid = getAutoCsUid();
  130. $userInfo=UserModel::where($where)->withoutField('register_ip,login_count,update_time,create_time')->find();
  131. if($userInfo==null){
  132. $salt = \utils\Str::random(4);
  133. $userInfo = UserModel::create([
  134. 'account'=>$params['account'],
  135. 'realname'=> !empty($params['realname']) ? $params['realname'] : $params['account'],
  136. 'name_py' => !empty($params['realname']) ? pinyin_sentence($params['realname']) : '',
  137. 'phone'=>!empty($params['phone']) ? $params['phone'] : '',
  138. 'email'=>!empty($params['email']) ? $params['email'] : '',
  139. 'from'=>$params['from'],
  140. 'uid'=>$params['uid'],
  141. 'salt' => $salt,
  142. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  143. 'password' => password_hash_tp(123456,$salt),
  144. 'cs_uid' => $cs_uid,
  145. 'role' => 0,
  146. 'status' =>1,
  147. 'register_ip' => $this->request->ip(),
  148. 'last_login_ip' => $this->request->ip(),
  149. 'last_login_time' => time(),
  150. 'login_count' => 1
  151. ]);
  152. // 监听用户注册后的操作
  153. event('UserRegister',['user_id' => $userInfo['user_id'], 'realname' => $userInfo['realname'], 'language_code' => $this->lang]);
  154. } else {
  155. //$userInfo['avatar']=avatarUrl($userInfo['avatar'],$userInfo['realname'],$userInfo['user_id']);
  156. // 如果用户已经有设置
  157. $setting=$userInfo['setting'] ?: '';
  158. if($setting){
  159. $setting['hideMessageName']= $setting['hideMessageName']=='true' ? true : false;
  160. $setting['hideMessageTime']= $setting['hideMessageTime']=='true' ? true : false;
  161. $setting['avatarCricle']= $setting['avatarCricle']=='true' ? true : false;
  162. $setting['isVoice']= $setting['isVoice']=='true' ? true : false;
  163. $setting['sendKey']= 1;//(int)$setting['sendKey'];
  164. $userInfo['setting']=$setting;
  165. }
  166. }
  167. if($userInfo['status']==1){
  168. return ret(lang('user.forbid'));
  169. }
  170. $update=[
  171. 'last_login_time'=>time(),
  172. 'last_login_ip'=>$this->request->ip(),
  173. 'login_count'=>Db::raw('login_count+1'),
  174. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  175. 'language' => $this->lang,
  176. ];
  177. if ($userInfo['cs_uid'] == 1) {
  178. $update['cs_uid'] = $cs_uid;
  179. }
  180. if (!empty($params['realname'])) {
  181. $update['realname'] = $params['realname'];
  182. }
  183. UserModel::where('user_id',$userInfo['user_id'])->update($update);
  184. //记录用户浏览
  185. if (!empty($_SERVER['HTTP_REFERER']))
  186. UserView::addData($_SERVER['HTTP_REFERER'],$userInfo['user_id']);
  187. Db::commit();
  188. } catch (\Exception $e) {
  189. Db::rollback();
  190. return error($e->getMessage());
  191. }
  192. //如果登录信息中含有client——id则自动进行绑定
  193. $client_id=$this->request->param('client_id');
  194. if($client_id){
  195. $cid=$this->request->header('cid','');
  196. $this->doBindUid($userInfo['user_id'],$client_id,$cid);
  197. }
  198. $userInfo['qrUrl']=getMainHost().'/scan/u/'.encryptIds($userInfo['user_id']);
  199. unset($userInfo['password'],$userInfo['salt']);
  200. $userInfo['displayName']=$userInfo['realname'];
  201. $userInfo['id']=$userInfo['user_id'];
  202. $authToken=UserModel::refreshToken($userInfo,$param['terminal'] ?? 'web');
  203. $data=[
  204. 'sessionId'=>Session::getId(),
  205. 'authToken'=>$authToken,
  206. 'userInfo'=>$userInfo
  207. ];
  208. return success(lang('user.loginOk'),$data);
  209. }
  210. // 执行绑定
  211. public function doBindUid($user_id,$client_id,$cid=''){
  212. // 如果当前ID在线,将其他地方登陆挤兑下线
  213. if(Gateway::isUidOnline($user_id)){
  214. wsSendMsg($user_id,'offline',['id'=>$user_id,'client_id'=>$client_id,'isMobile'=>$this->request->isMobile()]);
  215. }
  216. Gateway::bindUid($client_id, $user_id);
  217. // 查询团队,如果有团队则加入团队
  218. $group=Group::getMyGroup(['gu.user_id'=>$user_id,'gu.status'=>1]);
  219. if($group){
  220. $group=$group->toArray();
  221. $group_ids=arrayToString($group,'group_id',false);
  222. foreach($group_ids as $v){
  223. Gateway::joinGroup($client_id, $v);
  224. }
  225. }
  226. if($cid){
  227. bindCid($user_id,$cid);
  228. }
  229. wsSendMsg(0,'isOnline',['id'=>$user_id,'is_online'=>1]);
  230. }
  231. }