User.php 9.5 KB

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