User.php 9.9 KB

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